博客搬家,原地址:
https://langzi989.github.io/2017/09/20/UnixIPC中key_t类型本质/
System V IPC包括三种不同的通信机制
System V系统调用都有一个相关的get系统调用,它与文件io中的open函数类似,不同的是它的参数是一个整数,给定一个整数之后,系统会做以下操作:
上述IPC对象的标识类型为key_t。key_t的本质是什么?我们可以通过grep命令追踪到
在文件/usr/include/sys/ipc.h中:
#ifndef __key_t_defined
typedef __key_t key_t;
# define __key_t_defined
#endif
在文件/usr/include/bits/types.h中:
__STD_TYPE __KEY_T_TYPE __key_t; /* Type of an IPC key. */
在文件/usr/include/bits/typesizes.h中:
#define __KEY_T_TYPE __S32_TYPE
在文件中:
#define __S32_TYPE int
故从上面的追踪,可以看出key_t的本质为int类型.
获取ket_t的方法三种
IPC_PRIVATE本质上为0的宏定义.使用方法是直接使用IPC_PRIVATE作为key生成一个IPC对象。这种做法保证每次产生的都是全新的IPC对象。
这种做法适用于在父进程fork前创建IPC对象,从而达到子进程继承IPC对象的目的。
#include <sys/ipc.h>
key_t ftok(char* pathname, int proj);
此函数的功能是根据pathname和proj的值生成key,该算法只使用proj的最低的8个有效位,应用程序必须确保pathname引用一个可以应用stat()的既有文件。否则该函数会返回-1。
在linux中,key_t一般是32位的值。它通过取proj参数的最低8个有效位,包含该文件所属的文件系统的设备的设备号的最低8个有效位以及pathname所引用文件的inode号的最低16个有效位组合而成,这样保证了唯一性。所以从上面可以看出,对于同意个文件的不同路径(inode值相同),proj值相同,此时产生的key是相同的。