进程间的通信--管道

 管道的基本原理

        将一个进程的输出作为另一个进程的输入,将数据流从一个进程传递到另一个进程。在Unix或类Unix系统中,管道通常是通过操作系统内核中的一个缓冲区实现的,其输入和输出被映射到两个文件描述符上。一个进程通过向管道写入数据,另一个进程通过从管道读取数据,从而实现数据的传输。在实现上,管道可以是基于内存的匿名管道或基于文件系统的命名管道。实为内核使用环形队列机制,借助内核缓冲区(4k)实现。

管道的创建:

int pipe(int pipefd[2]);  定义在unistd.h//用于创建匿名管道,基于内存,只能在创建它的进程及其子进程之间使用,无法在其他进程之间共享。

我们使用匿名管道前会先调用fork创建子进程,管道也会复制一份,因此达到通信

通常我们用fd[0]用于读,fd[1]用于写

简便记忆:

1是管道头输入数据所以写,0是管道尾输出数据所以我们读,由此可知管道是半双工通信

int mkfifo(const char*filename,mode_t mode); 包含头文件sys/types.h和sys/stat.h

与打开open类似,//用于创建命名管道,基于文件,与匿名管道相反,但速度不如匿名管道

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值