IPC, 同步
IPC对象持续性
几种持续性
(1). 随进程
意味着使用它们的进程终止后,IPC
对象也会被销毁,删除
(2). 随内核
意味着系统启动中一直有效,下次开机,消失.
(3). 随文件
意味着持续存在于磁盘
IPC对象标识
IPC
对象要想在不同进程间共享,需要有一个标识.对象创建或打开时需要指定一个标识(为了让系统知道创建,打开的对象),对象创建或打开后会返回一个标识(后续对对象的访问操作均使用此返回标识).
IPC对象可用性
IPC
对象及关联的同步对象有很多,如管道/FIFO
/消息队列/共享内存/...
,互斥锁/读写锁/记录锁/条件变量/信号量/...
,并不是所有系统一定支持所有这些设施.有些是保证支持的,有些是否支持可用宏是否定义来判断,有些则未明确说明,具体见下表
fork, exec和exit对IPC对象影响
fork, exec, exit
是常用的进程控制手段,而IPC
对象又是服务于进程间通信的.故两者间的交互值得进行说明
Posix IPC, 同步
概述
对Posix IPC
的消息队列,信号量,共享内存打开时权限检查,和打开文件的权限检查一样.(三个IPC
对象也像文件一样有用户ID
,组ID
,且其获得方式和文件一样,三个IPC
对象打开/创建时的路径名是文件系统的路径名,还是其他不同内核实现下有不同要求)
System V IPC
上述三个IPC
对象的名字标识为key_t
类型,获取key_t
对象方式
(1). 用ftok
取得.
key_t ftok(const char* pathname, int id);
pathname
需要是一个有效路径名,且指向的文件应该是一个稳定存在的文件.有的系统,ftok
具体实现为用pathname
调stat
,取得st_dev,st_ino,id
低8
位组合返回一个key_t
对象.
同名文件删除又重建,前后两次文件的st_ino
等信息不能保证一致.
即使指定不同pathname
,但由于st_dev, st_ino
并不是全部位都参与key_t
构造,故不同pathname
也可能构造得到相同的key_t
(2). xxxget
的参数1
指定为IPC_PRIVATE
,此时内核保证xxxget
执行一个IPC
对象的创建,这种不好的方面是进程间利用IPC
对象通信时,没有显式的名字标识通知其他进程如何取得某个已经用IPC_PRIVATE
创建的IPC
对象
创建和打开IPC对象
几个xxxget
参数2
同时包含open
的flags
和mode
功能.且使用自己定义的IPC_xxx
宏
权限检查类似文件,打开已有对象执行一次.实际用打开描述符执行调用执行一次.System V
的上述3
个IPC
对象在内核空间管理