1、概念
POSIX信号量与SYSTEM信号量的作用相同,都是同步操作,达到无冲突地访问共享资源。但是不同的是,POSIX信号量可以用于线程间同步。其实,POSIX信号量是具有等待队列的计数器,它的相关函数存放在“semaphore.h”文件中。
2、初始化信号量
(1)函数原型:int sem_init(sem_t *sem, int pshared, unsigned int value)。
(2)参数:
1)pshared:0表示线程间共享,非0表示进程间共享。
2)value:信号量初始值,表示可用资源的数量。
3、销毁信号量
(1)int sem_destroy(sem_t *sem)。
(2)释:在用完semaphore变量后要调用sem_destroy()释放semaphore的相关资源。
4、等待信号量
(1)功能:等待信号量,会将信号量的值减1。
(2)函数原型:int sem_wait(sem_t *sem)。
(3)释:调用sem_wait()可以获得资源(P操作),使得semaphore的值减1,如果调用sem_wait()时semapthore的值已经是0,则挂起等待。如果不希望挂起等待,可以调用sem_trywait()。
5、发布信号量
(1)功能:发布信号量,将信号量值加1,表示资源使用完毕,可以归还资源了,。
(2)函数原型:int sem_post(sem_t *sem)。
(3)释:调用sem_post()可以释放资源(V操作),使得semaphore的值加1,同时唤醒挂起等待的线程。
【例】让生产者和消费者实现同步
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<semaphore.h>
sem_t product;
sem_t consume;
void *thr_product(void *arg)
{
while(1){
sem_wait(&product);
printf("product!\n");
sleep(1);
sem_post(&consume);
}
}
void *thr_consume(void *arg)
{
while(1){
sem_wait(&consume);
printf("consume!\n");
sleep(1);
sem_post(&product);
}
}
int main()
{
pthread_t tid1, tid2;
int err;
sem_init(&product, 0, 1);
sem_init(&consume, 0, 0);
err = pthread_create(&tid1, NULL, thr_product, NULL);
if(err != 0){
perror("create thread 1 error!\n");
return -1;
}
err = pthread_create(&tid2, NULL, thr_consume, NULL);
if(err != 0){
perror("create thread 2 error!\n");
return -1;
}
pthread_join(tid1, NULL);
pthread_join(tid2, NULL);
sem_destroy(&product);
sem_destroy(&consume);
return 0;
}
运行结果:
释:初始化信号量时把“product”的可用资源数量置1,这样,sem_wait(&product)将能执行。生产后把信号发布给“thr_consume”线程消费。