Linux管道(pipe)是一种特殊的文件,它专门用来在父/子进程和其他具有特定父子关系的进程之间进行通信。它提供了一种快速简单的方式,可以将一个进程的输出(标准输出)作为另一个进程的输入(标准输入)。利用Linux管道可以实现多进程通信,下面我们来看一个使用管道实现多进程通信的实例。

这个实例中,我们创建一个父进程来开启一个管道(可以是全双工或者半双工),然后建立一个子进程来向管道里写入一些内容,父进程从管道里读取内容,最后通过printf的方式将内容打印出来。
int pipefd[2];
pid_t childpid;
char readbuffer[80];
//创建一个管道
pipe(pipefd);
//创建一个子进程
childpid = fork();
if(childpid == 0)
//子进程往管道里写入一些内容
char *str=”This is from Child Process..”;
close(pipefd[0]);
write(pipefd[1], str, sizeof(str));
close(pipefd[1]);
//父进程从管道里读出内容
close(pipefd[1]);
read(pipefd[0], readbuffer, sizeof(readbuffer));
printf(“Received String : %s\n”, readbuffer);
close(pipefd[0]);
从上面的实例中,我们可以看到如果要实现多进程间的通信,可以使用Linux管道。它可以让父进程和子进程之间的通信变得更加便利,而且操作简单。使用管道可以大大减少通信复杂性,让程序员编写出更加简洁、稳定的代码。
香港服务器首选树叶云,2H2G首月10元开通。树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云 服务器 和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
Linux的管道命令如何使用?
管道命令具有过滤特性,一条命令通过标准输入端口接收一个文件中的数据,命令执行后产生的结果数据又通过标准输出端口送给后一条命令,作为第二条命令的输入数据。 第二条数据也是通过标准输入端口接收输入数据。 shell提供管道命令|把这些命令前后衔接在一起,形成一个管道线。 -ef|grep mysqld 这个竖线|就是管道命令的体现。 卢韬旭
linux有哪些优点?
完全的多任务
虚拟内存.
X window系统支持.
内置网络支持.
共享库.
同IEEE POSIX.1(Portable Operating System Interface)标准兼容,由于这一兼容性,Linux支持许多为所有UNIX系统提出的标准.
非专有资源代码.
费用低于大多数UNIX的克隆系统—如果你有耐心和时间,可以从Internet 上把Linux下载下来,而且许多图书都附有它的光盘拷贝.
GNU软件支持.
linux 编程问题 在主进程中创建2个子进程,一个用exec函数,一个用fork
编写一段程序,使用系统调用fork( )创建两个子进程。 当此程序运行时,在系统中有一个父进程和两个子进程活动。 让每一个进程在屏幕上显示一个字符;父进程显示字符“a”,子进程分别显示字符“b”和“c”。 试观察记录屏幕上的显示结果,并分析原因。 〈程序〉 #include main() { int p1,p2; if(p1=fork()) /*子进程创建成功*/ putchar(b); else { if(p2=fork()) /*子进程创建成功*/ putchar(c); else putchar(a); /*父进程执行*/ } } bca(有时会出现abc的任意的排列) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 编制一段程序,实现进程的管道通信。 使用系统调用pipe()建立一条管道线。 两个子进程p1和p2分别向通道个写一句话: child1 process is sending message! child2 process is sending message! 而父进程则从管道中读出来自两个进程的信息,显示在屏幕上。 〈程序〉 #include #include #include int pid1,pid2; main( ) { int fd[2]; char outpipe[100],inpipe[100]; pipe(fd); /*创建一个管道*/ while ((pid1=fork( ))==-1); if(pid1==0) { lockf(fd[1],1,0); sprintf(outpipe,child 1 process is sending message!); /*把串放入数组outpipe中*/ write(fd[1],outpipe,50); /*向管道写长为50字节的串*/ sleep(5); /*自我阻塞5秒*/ lockf(fd[1],0,0); exit(0); } else { while((pid2=fork( ))==-1); if(pid2==0) { lockf(fd[1],1,0); /*互斥*/ sprintf(outpipe,child 2 process is sending message!); write(fd[1],outpipe,50); sleep(5); lockf(fd[1],0,0); exit(0); } else { wait(0); /*同步*/ read(fd[0],inpipe,50); /*从管道中读长为50字节的串*/ printf(%s\n,inpipe); wait(0); read(fd[0],inpipe,50); printf(%s\n,inpipe); exit(0); } } } 〈运行结果〉延迟5秒后显示: child1 process is sending message! 再延迟5秒: child2 process is sending message! 附:我承认我是复制的 不过很符合题意~
发表评论