POSIX信号量有两种形式:命名的和未命名的。它们的差异在于创建和销毁的形式上,但是其他工作一样。
未命名的信号量只存在于内存中,并要求能使用信号量的进程必须可以访问内存。这意味着它们只能应用在同一进程中的线程,或者不同进程中已经映射相同内存内容到它们的地址空间中的线程。
命名信号量可以通过名字访问,因此可以被任何已知它们名字的进程中的线程使用。
我们可以调用sem_open函数来创建一个新的命名信号量或者使用一个现有信号量。
#include <semaphore.h>
sem_t *sem_open(const char *name,int oflag,...)
//成功返回信号量的指针,出错返回SEM_FAILED
当使用一个现有的命名信号量时,我们仅仅指定两个参数:信号量的名字和oflag参数的0值。
当我们指定O_CREAT标志时,需要提供两个额外参数。mode参数指定谁可以访问信号量。
在创建信号量的时候,value参数用来指定信号量的初始值。它的取值时0-SEM_VALUE_MAX。
如果我们想确保创建的是信号量,可以设置oflag参数为O_CREAT|O_EXCL。如果信号量已经存在,会导致sem_open失败。
为了增加可移植性,在选择信号量命名时必须遵循一定的规则:
- 名字的第一个字符应该为斜杠。
- 名字不应包含卡斜杠以此避免实现定义的行为
- 信号量名字的最大长度时实现定义的。
如果想在信号量上进行操作,sem_open函数会为我们返回一个信号量指针,用于传递到其他信号量函数上,但完成信号量操作的时候,可以调用sem_close函数来释放任何信号量相关的资源。