进程间通信方法一:匿名管道
系统中的公共资源由操作系统(内核)提供,进程间互相独立,各不干扰。
如果一份资源可被多个进程访问,则被称为临界资源。
临界资源需要被保护,临界资源任意时刻保证只有一个进程在访问,且任何进程访问临界资源时要保持原子性,以原子形式读写,互斥访问。
进程间的的通信方法有多种,这篇博客介绍一下其中的一种通信方式,匿名管道(pipe)。
管道是一种最基本的IPC机制,由 pipe函数创建。
pipe函数调用成功返回0,失败返回-1。
函数原型为: int pipe(int pipefd[2])
匿名管道的特点有:
1.管道常用于有血缘关系的进程(如父子进程、兄弟进程)
2.管道是文件,进程退出时,文件会自动销毁,管道的生命周期随进程终止而消失,即随进程(生命周期)
3.管道内部已经完成同步,保持了数据的一致性
4.管道基于字节流
5.当管道被写满后,写者会一直进行阻塞式等待。
这种管道在通信时可能会发生四种情况
1.读者一直在读,写的停止写入,但是没有关闭描述符
2.写者一直在写,读的停止读出,但是没有关闭描述符
3.写者一直在写,读的停止读出,并且关闭描述符
4.读者一直在读,写的停止写入,并且关闭描述符