POSIX信号量
DESCRIPTION
POSIX 信号量允许进程间和线程间同步他们的操作. 一个信号量是一个整型(integer),其值不能小于0. 信号量允许2中操作:给信号量的值加1(sem_post); 给信号量的值减一(sem_wait).
如果信号量的值为0, 那么sem_wait() 函数将会阻塞, 直到信号量的值大于0才会解除阻塞. POSIX 信号量有两种形式: 有名信号量 和 无名信号量.
Named semaphores
一个有名信号量有一个唯一的名字, 名字的格式是 /somename; 名字是以NULL结尾的字符串,最大长度不超过NAME_MAX-4 (减4的原因见Accessing named semaphores via the filesystem) 个字节(包括最前面的斜线),
除了首个字节是斜线外,之后的任何字节都不能是斜线.
两个进程可以通过给 sem_open()函数传递相同名字来达到操作同一个信号量的目的.
函数sem_open() 可以创建一个新的有名的信号量 或者 打开一个既存的有名信号量. 信号量被打开后, 就可以使用函数 sem_post() 和 sem_wait() 来操作它.
当一个进程使用完了这个信号量后,他可以使用函数 sem_close() 来关闭这个信号量.
当所有的进程都不再使用这个信号量时,可以调用函数 sem_unlink() 将这个信号量从系统中删除.
Unnamed semaphores (memory-based semaphores)
无名信号量没有名字, 作为代替有名的方法,无名信号量被放置于一个多线程共享的内存区域中(线程共享的信号量) 或者多个进程共享的内存区域中(进程共享的信号量).
线程共享的信号量被放置于一个进程之内的多线程共享内存区,例如全局变量.
进程共享信号量必须被放置于共享内存中(例如使用shm_open()创建的共享内存对象).
在使用无名信号量之前, 必须使用函数 sem_init() 初始化这个无名信号量, 随后才可以使用 sem_post() 和 sem_wait() 来操作这个无名信号量.
当无名信号量不在使用时, 并且信号量所在的内存区域没有被释放, 使用 sem_destroy() 来删除这个无名信号量.
Versions
在linux内核2.6版本之前, Linux只支持无名,线程共享的信号量. 从Linux 内核 2.6版本起 ,glibc提供了NPTL线程实现, 完整的POSXI信号量被提供了.
Persistence(持续性)
信号量是随内核持续的: 如果不调用sem_unlink进行删除, 信号量会一直持续到系统关闭.
Linking
编译时需要链接pthread库.
Accessing named semaphores via the filesystem
在Linux上, 有名信号量时在虚拟文件系统中创建的, 通常挂载在目录 /dev/shm 下, 名字的形式是 sem.somename (信号量名字长度是 NAME_MAX-4 的原因)。
从Linux内核2.6.19版本起, Linux支持使用访问控制列表(ACLs) 来控制虚拟文件系统中对象的权限.
Inherit
CONFORMING TO
POSIX.1-2001.
NOTES
System V 的信号量是过时的, POSIX信号量提供了使用更简单、设计更合理的API.
API List
- sem_close - close a named semaphore
- sem_destroy - destroy an unnamed semaphore
- sem_getvalue - get the value of a semaphore
- sem_init - initialize an unnamed semaphore
- sem_open - initialize and open a named semaphore
- sem_post - unlock a semaphore
- sem_timedwait - lock a semaphore
- sem_trywait, sem_wait - lock a semaphore
- sem_unlink - remove a named semaphore
- sem_wait - lock a semaphore
POSIX信号量的更多相关文章
- 第10章 Posix 信号量
10.1 概述 10.1.1 信号量类型 Posix有名信号量:使用Posix IPC名字,可用于进程或线程间同步: Posix基于内存的信号量:也叫做无名信号量,存放在共享内存中,可用于进程或线程间 ...
- 进程间通信之POSIX信号量
POSIX信号量接口,意在解决XSI信号量接口的几个不足之处: POSIX信号量接口相比于XSI信号量接口,允许更高性能的实现. POSIX信号量接口简单易用:没有信号量集,其中一些接口模仿了我们熟悉 ...
- Linux进程间通信IPC学习笔记之同步二(Posix 信号量)
Linux进程间通信IPC学习笔记之同步二(Posix 信号量)
- Linux进程同步之POSIX信号量
POSIX信号量是属于POSIX标准系统接口定义的实时扩展部分.在SUS(Single UNIX Specification)单一规范中,定义的XSI IPC中也同样定义了人们通常称为System V ...
- Linux多线程实践(5) --Posix信号量与互斥量解决生产者消费者问题
Posix信号量 Posix 信号量 有名信号量 无名信号量 sem_open sem_init sem_close sem_destroy sem_unlink sem_wait sem_post ...
- linux POSIX 信号量介绍
信号量一.什么是信号量信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)使用.多线程可以同时运行多个线程函数完成功能,但是对于共享数据如果不加以锁定,随意改变共享数据的值会发生 ...
- posix信号量与互斥锁
1.简介 POSIX信号量是一个sem_t 类型的变量,但POSIX 有两种信号量的实现机制:无名信号量和命名信号量.无名信号量可以用在共享内存的情况下, 比如实现进程中各个线程之间的互斥和同步.命名 ...
- linux Posix 信号量 二
一.Posix信号量 1.Posix信号量分为两种: 1. 有名信号量:使用Posix IPC名字标识(有名信号量总是既可用于线程间的同步,又可以用于进程间的同步) 2. 内存信号量:存放在共 ...
- linux Posix 信号量 一
信号量是一种用于提供不同进程间或一个给定进程的不同线程间同步手段的原语. linux提供两种信号量,“内核信号量”和“用户态进程信号量”,“用户态信号量”又分为“Posix”,“System V”信号 ...
随机推荐
- [SDOI2013]森林 主席树+启发式合并
这题的想法真的很妙啊. 看到题的第一眼,我先想到树链剖分,并把\(DFS\)序当成一段区间上主席树.但是会发现在询问的时候,可能会非常复杂,因为你需要把路径拆成很多条轻链和重链,它们还不一定连续,很难 ...
- python实现查找文件
import os.pathwhile True: rootdir=input('请输入遍历文件夹的绝对路径:(q退出)') if rootdir=='q': break if not(os.path ...
- Vue(四)组件
组件的复用 这里的工程和上一节的一样 先建立一个组件 MyButton.vue <template> <button @click="count++">Yo ...
- 第九周博客作业<西北师范大学|李晓婷>
1.助教博客链接:https://home.cnblogs.com/u/lxt-/ 2.作业要求博客链接:https://www.cnblogs.com/nwnu-daizh/p/10726884.h ...
- axios传参
get //通过给定的ID来发送请求 axios.get('/user?ID=12345') .then(function(response){ console.log(response); }).c ...
- Jenkins-在windows上配置自动化部署(Jenkins+Gitblit)
Jenkins-在windows上配置自动化部署(Jenkins+Gitblit) 1. 安装好 Jenkins(注:安装目录需没有空格,否则安装gitlab hook 插件时会报错,安装在c盘跟目录 ...
- hadoop记录-hadoop常用
1.hdfs目录配额 #设置配额目录hdfs dfsadmin -setSpaceQuota 10T /user/hive/warehouser/tmp查看配额目录信息hdfs dfs -count ...
- Airflow Comman Line 测试
官网文档:https://incubator-airflow.readthedocs.io/en/latest/cli.html clear (1)clear 指定日期某一个dag下的任务,任务名可以 ...
- markdown 数学公式
https://blog.csdn.net/zdk930519/article/details/54137476
- StackExchange.Redis 异步超时解决方案
Timeout awaiting response (outbound=0KiB, inbound=45417KiB, 5891ms elapsed, timeout is 5000ms), comm ...