进程间通信的一种方式就是使用共享内存,Linux下与共享内存相关的系统调用是编程的基础,根据项目中的使用情况,罗列如下。
key_t ftok(constchar * pathname, int id)
系统建立IPC通信(消息队列、信号量、共享内存)时必须指定一个ID值。ftok函数根据一个文件和子序号生成这样一个键值,唯一标识此资源。
int shmget(key_tkey, size_t size, int shmflg)
创建新的共享内存或者获取一段已经存在的共享内存。key唯一标识共享内存。如果创建则必须指定size,如果获取则可以将size设置为0。shmflg是标志位,标识共享内存的属性。该调用成功返回共享内存标识符,失败返回-1,根据errno,由strerror_r函数获取错误信息。
void* shmat(intshm_id, void* shm_addr, int shmflg)
将共享内存映射到进程地址空间。shm_id是shmget返回的共享内存标识符,shm_addr是共享内存被映射到的地址,推荐使用NULL,由系统决定,确保可移植性。成功返回映射地址,失败返回-1。
int shmdt(constvoid * shm_addr)
取消映射,成功返回0,失败返回-1。
int shmctl(intshm_id, int command, struct shmid_ds* buf)
控制共享内存属性。删除共享内存时,会将IPC_RMID命令设置上,当最后一个使用该共享内存的进程调用shmdt后,该共享内存被删除。
共享内存使用时需要进行同步管理,一般会同时分配一块内存存放锁,各进程在使用时先获取锁在操作数据读写。读写锁相关数据结构和系统调用包括:
pthread_rwlock_trwlock 读写锁结构体
pthread_rwlockattr_trwlockattr 读写锁属性结构体
pthread_rwlockattr_int(&rwlockattr)初始化属性
pthread_rwlockattr_setpshared(&rwlockattr,PTHREAD_PROCESS_SHARED)设置跨进程共享。
pthread_rwlock_init(&rwlock,&rwlockattr)用属性初始化读写锁
pthread_rwlockattr_destroy(&rwlockattr)销毁属性结构体
pthread_rwlock_rdlock(&rwlock)读方式加锁
pthread_rwlock_wrlock(&rwlock)写方式加锁
pthread_rwlock_unlock(&rwlock)解锁
pthread_rwlock_destroy(&rwlock)销毁锁