进程之间进行通信
实质:信息(数据)的交换
进程的地址空间是独立的,所以无法使用全局变量进行实现通信。
如果要实现进程间的通信,那么就必须把数据或信息放到一个两个或多个进程都能够访问到的地方。
进程的通信方式
管道 :pipe (无名管道) fifo (有名管道)
信号:signal
消息队列 System V消息队列/POSIX消息队列
信号量 System V 信号量/POSIX信号量
共享内存 System V 共享内存/POSIX共享内存
管道
1.pipe (无名管道)
在文件系统中没有文件名(无Inode),它的内容存在内核中。
pipe在创建的时候,在内核中开辟一块缓冲区,作为pipe文件的内容
的存储空间,同时返回两个文件描述符(一个文件描述符fd[0]用来读的,
另一个文件描述符fd[1] 是用来写的),还有如下特点:
a、pipe有两端,一端用来写,一端是用来读的
b、按顺序读,不支持lseek
c、内容读走了,就没有了。
d、pipe随内核持续性的。
函数
int pipe(int pipefd[2]);
作用:
pipe用来在内核中创建一个无名管道,pipefd用来
保存创建好的无名管道的两个文件描述符的。
pipe创建管道的方式,默认是“阻塞方式”
pipefd : 有两个int类型元素的数组
pipefd[0] : 保存读的文件描述符
pipefd[1] : 保存写的文件描述符
返回值:
成功返回0
失败返回-1,errno被设置。
注意: