进程间通信
1 管道 :通信效率低,不适合进程间频繁交换数据
分为匿名管道跟命名管道
匿名管道用完了就销毁,它的通信范围存在父子关系的进程间,通信的方式是单向的,由于没有管道文件,只能通过fork复制父进程文件扫描符,以达到通信目的
命名管道可以在不相干的进程间通信,它会提前创建一个管道类型的设备文件,在进程内使用这个设备文件就能够相互通信
2 消息队列 :克服了管道通信的数据是无格式子节流的问题,但不适合较大数据的传输,因为内核中消息体拥有最大长度,所有队列包含的消息体长度也有限制。在通信过程中还会存在用户态与内核态之间的数据拷贝开销,进程写入数据到内核会发生从用户态拷贝数据到内核态的过程
3 共享内存 :拿出一块虚拟的地址空间,映射到相同的物理内存中,这样两个进程的交互就避免了需要多次拷贝数据的情况。
4 信号量 :多个进程同时访问共享内存会出错,因此设置了一个保护机制,使得共享资源在某一刻只能被一个进程访问。能够实现线程间互斥与同步。
5 信号 :进程间唯一的异步通信机制,可以在应用进程和内核之间直接通信,进程有三种方式相应信号 1,执行默认操作 2,捕捉信号3,忽略信号
6 Socket : 能够在同主机间进程的通信,同时也实现了跨域的进程通信。