Linux編程:多個子進程與父進程使用匿名管道讀寫

編寫程序,在程序中父進程先後創建子進程1和子進程2。父子三個進程併發執行,並利用同一個匿名管道通信:兩個子進程分別向管道寫一則信息(內容自定,但要求包含子進程信息);父進程從管道讀出信息並顯示出來(要求先接收子進程1的信息)

#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/wait.h>
#include<string.h>
int main()
{
	pid_t pid,pid_1,pid_2;
	int status;
	int fd[2];
	int ret=pipe(fd);
	if(ret==-1) 
	{perror("pipe error"); exit(1);}

	int i;

	for( i=0;i<2;i++)
		{
			pid=fork();
			if(pid==0&&i==0) //子進程1
			{
				pid_1=getpid();break;
			}	
			if(pid==0&&i==1) //子進程2
			{
				pid_2=getpid();break;
			}
		}
	if(pid==-1)
		{	perror("fork error\n");	exit(1); }

	if(i==0)//子進程1
	{
		close(fd[0]);
		//char *p="我是子進程1,我的pid=";
		//write(fd[1],p,strlen(p)+1);
char c[100]="";
		sprintf(c,"我是子進程:%d,我的pid=%d\n",i+1,pid_1);
		write(fd[1],&c,strlen(&c)+1);
	}else if(i==1)//子進程2
	{
		waitpid(pid_1,&status,0);//等待子進程1執行完畢
		close(fd[0]);
		char d[100]="";
		sprintf(d,"我是子進程:%d,我的pid=%d\n",i+1,pid_2);
		write(fd[1],&d,strlen(&d)+1);
	}else if(i==2)//父進程
	{
		waitpid(pid_2,&status,0);
		close(fd[1]);
		char buf[100]={0};
		ret=read(fd[0],buf,sizeof(buf));
		close(fd[0]);
		write(STDOUT_FILENO,buf,ret);
	}
		return 0;
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章