进程之间的通信
什么是IPC?
进程间通信,InterProcess Communication
进程间通信常用的4中方式
管道----------简单
信号----------系统开销小
共享映射区----(有无学院关系的进程间通信都可以)
本地套接字-----稳定
什么是管道?
本质:
内核缓冲区
伪文件-不占用磁盘空间
特点:
两部分:
读端、写端,对应两个文件描述符
数据写端流入,读端流出
操作管道的进程被销毁之后,管道被自动释放
对管道的操作,默认阻塞。
管道的原理
内部实现方式:队列
环形队列
特点:先进先出
缓冲区大小:
默认4k
但也会根据实际情况适当调整
管道的局限性
队列:
数据只能读取一次,不能重复读,读完之后就销毁了。
半双工:
单工:只能一方向另一方发送
半双工:双方都能发送和接受,但是同一时刻只能一方发送
双工:同时双发送
匿名管道:
适用于有血缘关系的进程。
那么什么样的有血缘关系呢?
父子、爷孙、叔侄,因为fork是对父进程的赋值,除了pcbid不一样其它都已一样。包括文件描述符表
如何创建匿名管道?
int pip(int fd[2]);
//fd-传出参数
//fd[0] //读端
//fd[1] //写端
程序示例
#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<string.h>
int main(int argc,const char * argv[]){
int fd[2];
int ret=pipe(fd);
if(ret==-1){
perror("pipe error"</