管道
进程间通信
进程间通信是不能直接靠两个进程直接建立连接进行通信,需要依靠操作系统提供一个进程间都可以访问到的区域进行
两个进程的共同访问,因为适用的场景不通,所以分为几种进程间的通信方式:消息队列、共享内存、管道、信号量
进程间不能进行直接通信的原因:进程具有独立性,每个进程其实就是一个单独pcb,他们有自己独有的虚拟空间地址
进程间只能访问自己的虚拟地址空间的虚拟地址,因而需要操作系统提供一个共享区域来实现进程间的相互通信
管道:实质上是用于实现进程间通信的一块内核缓冲区,管道属于半双工通信,用于进行进程间数据的传输通信
管道的种类:
1.匿名管道:内核中的缓冲区没有标识,只能用于具有亲缘关系的进程间通信
2.命名管道:内核中的缓冲区有自己的标识,可以用于主机中所有的进程
匿名管道:
1.进程通过系统调用接口在内核中创建管道:int pipe(int pipefd[2] );
2.通过这个接口操作系统返回管道的操作句柄
3.管道的操作方式类似于文件操作(通过文件描述符以及IO接口访问)
4.创建子进程,子进程复制了父进程,同时也有了同一个管道的操作句柄
int pipefd[2]: pipefd【2】表示接收管道的操作句柄,pipefd[0]:表示从管道中读数据