头文件:#include <semaphore.h>
链接库 -pthread
函数原型: int sem_init(sem_t *sem, int pshared, unsigned int value); 参数说明: a. sem为指向未初始化信号量结构的一个指针 b. pshared参数表示这个信号量是在进程的线程之间共享,还是在进程之间共享。 如果pshared的值为0,那么这个信号量会在进程的线程之间共享,并且应该位于对所有线程都可见的某个地址 如果pshared非零,那么这个信号量将在进程之间共享,并且应该位于共享内存的某个区域(参见shm_open(3)、
mmap(2)和shmget(2))。(因为fork(2)创建的子进程会继承父进程的内存映射,所以它也可以获取信号量)。
任何可以访问共享内存区域的进程都可以使用sem_post(3)、sem_wait(3)等对这个信号量进行操作。 c. value指定信号量的初始值 功能: 初始化信号量 返回值:成功返回0,失败返回-1
函数原型: int sem_destroy(sem_t *sem); 参数说明: sem为通过sem_init(3)初始化的信号量 功能: 释放信号量 返回值:成功返回0,失败返回-1
函数原型: int sem_post(sem_t *sem); 参数说明: sem为通过sem_init(3)初始化的信号量 功能: sem_post函数的作用是给信号量的值加上一个“1”,它是一个“原子操作”---即同时对同一个信号量做加“1”操作的两个线程是不会冲突的;
而同 时对同一个文件进行读、加和写操作的两个程序就有可能会引起冲突。信号量的值永远会正确地加一个“2”--因为有两个线程试图改变它。 返回值:成功返回0,失败返回-1
函数原型: int sem_wait(sem_t *sem); 参数说明: sem为通过sem_init(3)初始化的信号量 功能: sem_wait函数也是一个原子操作,它的作用是从信号量的值减去一个“1”,但它永远会先等待该信号量为一个非零值才开始做减法。
也就是说,如果你对 一个值为2的信号量调用sem_wait(),线程将会继续执行,介信号量的值将减到1。如果对一个值为0的信号量调用sem_wait(),
这个函数就 会地等待直到有其它线程增加了这个值使它不再是0为止。如果有两个线程都在sem_wait()中等待同一个信号量变成非零值, 那么当它被第三个线程增加 一个“1”时,等待线程中只有一个能够对信号量做减法并继续执行,另一个还将处于等待状态。 返回值:成功返回0,失败返回-1