C语言进程通过管道同步
2013-08-21 10:10
190 查看
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
int main()
{
int piple_file[2]; //管道文件
int res,get_data_nu,data;
res=pipe(piple_file); //生成管道文件
if(res==0)
{
res=fork(); //创建新进程
if(-1==res)
{
perror("fork failed \n");
exit(-1);
}
if(0==res) //子进程,子进程是消费者
{
int i=0;
for(i;i<10;i++)
{
get_data_nu=read(piple_file[0],&data,sizeof(int)); //往管道中读数据,通过管道为空时等待而使得与父进程同步
printf("get %d from piple_file0\n",data);
}
exit(0);
}else //父进程,父进程是生产者
{
int i=0;
for(i;i<10;i++)
{
write(piple_file[1],&i,sizeof(int)); //往管道中写数据
printf("write %d to piple_file[1]\n",i);
sleep(1);
}
}
}
exit(0);
}
==============================================================================================
更一般的通过管道通信和同步可以这样:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
int main()
{
pid_t current_pid;
int piple_file[2];
int res,get_data_nu,data;
res=pipe(piple_file);
if(res==0)
{
//sleep(8);
res=fork();
if(-1==res)
{
perror("fork failed \n");
exit(-1);
}
if(0==res)
{
int i=0;
char buff[BUFSIZ];
sprintf(buff,"%d",piple_file[0]); //把fid转换为字符串
printf("%s the fid is %d\n",buff,piple_file[0]);
execl("pipe4","pipe4",buff,(char *)0); //pipe4是一个应用程序
printf("ok........\n");
exit(0);
}else
{
int i=0;
for(i;i<10;i++)
{
write(piple_file[1],&i,sizeof(int));
printf("write %d to piple_file[1]\n",i);
sleep(1);
}
}
}
exit(0);
}
===================================pipe4.c=================================
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
int main(int argc,char * argv[])
{
int fid,date;
int i=0;
printf("Hello ! %s\n",argv[1]);
sscanf(argv[1],"%d[0-9]",&fid); //通过转换得到整形的fid号(即管道号)
printf("the pid is %d\n",fid);
for(i;i<10;i++)
{
read(fid,&date,sizeof(int)); // 从管道中读取数据
printf("read %d from fid %d\n",date,fid);
}
exit(0);
}
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
int main()
{
int piple_file[2]; //管道文件
int res,get_data_nu,data;
res=pipe(piple_file); //生成管道文件
if(res==0)
{
res=fork(); //创建新进程
if(-1==res)
{
perror("fork failed \n");
exit(-1);
}
if(0==res) //子进程,子进程是消费者
{
int i=0;
for(i;i<10;i++)
{
get_data_nu=read(piple_file[0],&data,sizeof(int)); //往管道中读数据,通过管道为空时等待而使得与父进程同步
printf("get %d from piple_file0\n",data);
}
exit(0);
}else //父进程,父进程是生产者
{
int i=0;
for(i;i<10;i++)
{
write(piple_file[1],&i,sizeof(int)); //往管道中写数据
printf("write %d to piple_file[1]\n",i);
sleep(1);
}
}
}
exit(0);
}
==============================================================================================
更一般的通过管道通信和同步可以这样:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
int main()
{
pid_t current_pid;
int piple_file[2];
int res,get_data_nu,data;
res=pipe(piple_file);
if(res==0)
{
//sleep(8);
res=fork();
if(-1==res)
{
perror("fork failed \n");
exit(-1);
}
if(0==res)
{
int i=0;
char buff[BUFSIZ];
sprintf(buff,"%d",piple_file[0]); //把fid转换为字符串
printf("%s the fid is %d\n",buff,piple_file[0]);
execl("pipe4","pipe4",buff,(char *)0); //pipe4是一个应用程序
printf("ok........\n");
exit(0);
}else
{
int i=0;
for(i;i<10;i++)
{
write(piple_file[1],&i,sizeof(int));
printf("write %d to piple_file[1]\n",i);
sleep(1);
}
}
}
exit(0);
}
===================================pipe4.c=================================
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
int main(int argc,char * argv[])
{
int fid,date;
int i=0;
printf("Hello ! %s\n",argv[1]);
sscanf(argv[1],"%d[0-9]",&fid); //通过转换得到整形的fid号(即管道号)
printf("the pid is %d\n",fid);
for(i;i<10;i++)
{
read(fid,&date,sizeof(int)); // 从管道中读取数据
printf("read %d from fid %d\n",date,fid);
}
exit(0);
}
相关文章推荐
- UNIX环境高级编程学习之第十五章进程间通信 - 通过匿名管道实现父子进程同步
- APUE-通过管道同步父子进程
- 通过命令管道,在进程之间进行通信的简单例子
- [ZZ]使用命名管道通过网络在进程之间进行通信
- Linux下用fork()派生的子进程通过pipe管道通讯的实例详解("生产者-消费者"问题)
- UNIX环境高级编程学习之第十五章进程间通信 - 通过半双工匿名管道实现父子进程通信
- 【说解】在shell中通过mkfifo创建命名管道来控制多个进程并发执行
- 在C语言中通过分叉进程监控程序被卸载&调用浏览器跳转填写建议
- 通过匿名管道在进程间双向通信
- php通过fork和管道实现多进程
- linux进程间通过管道通信实现简单的tftp
- linux c之通过管道实现兄弟间进程通信:
- 使用命名管道通过网络在进程之间进行通信(C#)
- C#进程同步之管道通信
- 父进程下的两个子进程通过管道进行通信
- 通过管道向CMD进程写新指令时回显More?
- 进程间同步(Process Synchronization)-2 通过semaphore方式来实现进程间同步的例子
- C++和C#进程之间通过命名管道通信(上)
- C通过管道获取LINUX进程内存占用情况
- Unix编程(二)C语言利用PV原句解决5个经典的进程同步问题