semaphore and mutex
来源:互联网 发布:我的世界双持js 编辑:程序博客网 时间:2024/06/07 06:49
进程间共享的资源,通过semaphore 来保护,
semget( ), get semaphore set identifier.
semctl ( ), init semaphore element,
semop( ), operate the semaphore element of set,
而线程间的共享资源(such as share memory),通过pthread_mutex_lock( ) and pthread_mutex_unlock( )来保护。
下面是semaphore的几个系统调用:
int semget(key_t key, int nsems, int semflg); 返回与 key 相关联的semaphore set identifier;
nsems: 创建的semaphore element 个数;如果semflg = IPC_CREAT, 或者 key = IPC_PRIVATE,则新的nsems 个semaphore elements 被创建;
semflg: 如果 semflg = IPC_CREAT | IPC_EXCL;则如果key所标识的semaphore set 已经存在,则返回出错。
if successful, 返回 semaphore set identifier; otherwise, 返回-1,错误码存放在errno里。
int semctl(int semid, int semnum, int cmd, ...); 在semid 所指定的semaphore set 上(或者第semnum个element of set 上)执行 cmd 所标识的操作。valid values for cmd are:
IPC_RMID: remove the semaphore set immediately,
int semop(int semid, struct sembuf *sops, unsigned nsops);
struct sembuf,包含下面几个字段:
unsigned short sem_num; /* semaphore number */
short sem_op; /* semaphore operation */
short sem_flg; /* operation flags */
- semaphore and mutex
- Difference between mutex and semaphore
- Semaphore and Mutex usages and differences
- Semaphore And Mutex - 信号量与互斥锁
- Producer Consumer problem - mutex and semaphore
- semaphore mutex
- mutex和semaphore
- Semaphore VS Mutex
- 理解Semaphore和Mutex
- spinlock mutex semaphore rwlock
- 理解Semaphore和Mutex
- Semaphore和Mutex比较
- Mutex vs. Semaphore
- mutex, spinlock, semaphore
- Mutex和Semaphore区别
- semaphore与Mutex
- Mutex和Semaphore区别
- spinlock, semaphore 和 mutex
- int与字节数组互相转换
- MSP430RAM内数组分配问题,实验结果
- list 异步加载图片
- Ice Cream Sandwich 4.0 Build Guidance
- Java内存对象的逃逸分析
- semaphore and mutex
- fsl imx51 android真机调试
- ubutu 突然看不到共享文件夹 原来是更新后vmtools发神经 或者是更新ubuntu的原因 所以没事别更新啊
- web工程初始化spring容器, 并读入总配置文件
- 10 个很棒的 jQuery 代码片段
- vi命令参考
- 设置Chrome以https方式访问指定网址
- hibernate hql 详解
- 打败system,自己监听Home键