15进程间通信

15.2管道

1)历史上是半双工的。现在,系统提供全双工管道。

2)只能在具有公共祖先的进程之间使用。

#include<unistd.h>

int pipe(int filedes[2])

filedes[0]为读打开

filedes[1]为写打开。

filedes[1]输出是filedes[0]输入。

fstat函数对管道的每一端都返回一个FIFO类型的文件描述符,可以用S_ISFIFO宏来测试管道

当管道的一端被关闭后,下列两条规则起作用:

1)当读一个写端已被关闭的管道时,在所有数据都被读取后,read返回0,以指示达到了文件结束处。

2)如写一个读端已被关闭的管道,则产生信号SIGPIPE。如果忽略该信号或者捕捉该信号并从其处理程序返回,则write返回-,errno设置为EPIPE。

PIPE_BUF规定了内核中管道缓冲区的大小。如果对管道调用write,而且要求写的字节数小于等于PIPE_BUF,则此操作不会与其他进程对同一管道的write操作穿插进行。但是,若有多个进程同时写一个管道,而且有进程要求写的字节数超过PIPE_BUF字节数时,则写操作的数据可能相互穿插。

15.3popen和pclose函数

创建一个管道连接到另一个进程,然后读其输出或向其输入端发送数据,

#include <stdio.h>

FILE *popen(const char *cmdstring, const char *type)

int pclose(FILE*fp)

函数popen先执行fork,然后调用exec以执行cmdstring,并且返回一个标准I/O文件指针。如果type是r,则文件指针连接到cmdstring的标准输出。如果type是w,则文件指针连接到cmdstring的标准输入。

15.4协同进程

当一个程序产生某个过滤程序的输入,同时又读取该过滤程序的输出时,则该过滤程序就成为协同进程。

15.5FIFO

15.6XSI IPC

有三种IPC称作XSI IPC,即消息队列,信号量以及共享存储器,

每个内核中的IPC结构都用一个非负整数的标识符加以引用。当一个IPC结构被创建,以后又被删除时,与这种结构相关的标识符连续加1,直至达到一个整型数的最大正值,然后又回转到0.

标识符是IPC对象的内部名。外部名使用键,每个IPC对象都与一个键相关联,于是键就用作为该对象的外部名。

无论何时创建IPC结构,都应指定一个键,键的数据类型是基本系统数据类型key_t。

15.6.2权限结构

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值