查漏补缺:进程间通信(IPC):管道

  管道是UNIX系统IPC的最古老形式,所有UNIX系统都提供此种通信机制。管道有以下两种局限性:

  (1)历史上,管道是半双工的(即数据只能在一个方向上流动)。

  (2)管道只能在具有公共先祖的两个进程之间使用。通常,一个管道有一个进程创建,在进程调用fork之后,这个管道就能在父子进程间使用。

  管道的创建:

  管道通过调用pipe函数创建。

  头文件:#include <unistd.h>

  原型:int pipe(int fd[2])

  返回值:成功,返回0;失败,返回-1.

  经由参数fd返回两个文件描述符:fd[0]为 读而打开,fd[1]为写而打开。fd[1]的输出是fd[0]的输入。

  图解如下:

  

 

  测试程序:

复制代码
 1 #include <stdio.h>
 2 #include <unistd.h>
 3 #include <stdlib.h>
 4 
 5 int main(int argc,char* argv[])
 6 {
 7     int n;
 8     int fd[2];
 9     pid_t pid;
10     char buf[128] = {0};
11 
12     if(pipe(fd) < 0)
13     {
14         printf("pipe error\n");
15         return -1;
16     }
17 
18     if((pid = fork()) < 0)
19     {
20         printf("fork error\n");
21         return -1;
22     }
23     else if(pid > 0)
24     {
25         close(fd[0]);
26         printf("父进程ID:%d,子进程ID:%d\n",getpid(),pid);
27         write(fd[1],"hello world\n",sizeof("hello world\n"));
28     }
29     else
30     {
31         close(fd[1]);
32         n = read(fd[0],buf,sizeof(buf));
33         printf("子进程ID:%d\n",getpid());
34         write(STDOUT_FILENO,"子进程:",sizeof("子进程:"));
35         write(STDOUT_FILENO,buf,n);
36     }
37 
38     return 0;
39 
40 }
View Code
复制代码

 

posted @   落雷  阅读(231)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示