Linux ipc 编程以及线程同步

摘要:本文主要介绍管道,ystemv ipc机制,包括消息队列、信号量,共享内存。套接字也是进程间通信的一种机制。只是前面的机制都是在一台主机上的进程间通信。

共享内存

shmget
int shmget(key_t key, size_t size, int shmflg);
创建一个共享内存从key开始讲起,键值如果是IPC_PRIVATE,那么每次都是创建一个新的shm,也就是私有的,只有父子进程可以使用,除非把shmid发送给其他进程。shmflg只指定一个权限如0666,那么就只是打开一个shm;如果是0666|IPC_CREAT,那么就是创建一个新的共享内存;0666|IPC_CREAT|IPC_EXCL,那么就是shm存在就报错,不存在就创建。
创建的共享内存资源是有系统限制的, /proc/sys/kernel/shm…
程序访问shm时,实质访问的是内存,内存是以页为大小的。
shmat
shmdt
shmctl

消息队列

msgget
msgctl
msgsnd
msgrcv

信号量

semget
systemv信号量的创建是一个信号量集合,也就是说一个键值、semid可以对应多个信号量。这是要注意的点。
semctl
semop
p操作和v操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值