进程间通信介绍
1.unix系统上各种通信和同步工具,并根据功能将他们分成了三类
(1)通信:这些工具关注进程之间的数据交换
(2)同步: 这些进程关注进程和线程操作之间的同步
(3)信号:尽管信号的主要作用并不在此,但在特定场景下可以将它作为一种同步技术
2.数据传输工具:为了通信,一个进程将数据写入IPC工具,另一个从中读取数据。这些工具要求在用户内存和内核内存之间进行两次数据传输:一次传输时写入时从用户内存到内核内存,另一次传输是在读取时候从内核内存到用户内存
3.共享内存:共享内存允许进程通过将数据放到有进程间共享的一块内存中以完成信息的交换。
4.数据传输分为两大类:字节流(管道,fifo,数据包socket),消息(两种消息队列以及数据报socket)
5.共享内存:信号量用来作为同步的方法
6.信号量:一个信号量是一个内核维护的整数,其值永远不会小于0.一个进程可以增加或减小一个信号量的值。如果一个进程试图将信号量的值减小到小于0,那么内核会阻塞该操作直至信号量的增长到允许执行该操作的程度(或者非阻塞,直接返回错误)。一个进程减小一个信号量是为了预约对共享资源的独占访问,在完成了使用之后可以增加信号量。二元信号量使用较多,但处理一类共享资源拥有多个实例的应用程序需要使用最大值等于共享资源数量的信号量
7.文件锁:文件锁是设计用来协调操作同一个文件的多个进程的动作的一种同步方法。文件锁分为读锁和写锁。
8.互斥体和条件变量:这些同步工具通常用于posix线程
9.IPC持久性:只有当当显示的删除IPC对象或系统关闭,该对象才会被销毁,否则该对象会一直存在
读书笔记之linux/unix系统编程手册(43)
最新推荐文章于 2019-08-25 00:16:27 发布