进程间通信的目的
1、数据传输
一个进程将数据发送给另一个进程
2、资源共享
多个进程之间共享相同的资源
3、通知事件
第一个进程需要向另一个进程发送消息,通知发生的事件
4、进程控制
有些进程希望完全控制另一个进程的执行,此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够知道它的状态改变
进程间通信的本质就是两个互不相干的进程看到同一份资源,该资源一定是操作系统提供的。
进程间通信分类
管道
* 匿名管道
* 命名管道
System V IPC
* System V 消息队列
* System V 共享内存
* System V 信号量
POSIX IPC
* 消息队列
* 共享内存
* 信号量
* 互斥量
* 条件变量
* 读写锁
一、管道
本质上,管道也是一种文件,我们把一个进程连接到另一个进程的数据流称为管道
*匿名管道*
具有亲缘关系的进程进行数据间通信
我们创建一个子进程,通过管道实现子进程写的数据父进程可以读出来
1、父进程创建管道
2、父进程fork出子进程
3、父进程关闭写端、子进程关闭读端
代码实现:
匿名管道特点:
1、只能用于具有亲缘关系的进程
2、进程退出,管道释放,所以管道的生命周期随进程
3、内核会对管道操作进行同步与互斥(管道自带同步 )
4、单向传输,半双工的
5、管道是基于字节流的
四种情况:
* 写段关闭,读端一直在读,直到0值
* 写端不写也不关闭,读端一直在读
* 写端一直写,读端不读,管道满,等待读
* 写端一直写,读端关闭,写端被系统终止
命名管道
可以用于没有亲缘关系的进程
创建一个命名管道
方法一:
方法二:
匿名管道与命名管道的区别:
* 匿名管道由pipe函数创建并打开
* 命令管道由mkfifo函数创建,打开用open
* 匿名管道与匿名管道的唯一区别在于它们创建与打开方式不同
用命名管道实现客户端与服务器端之间的通信
server.c(服务器端)