0

我浏览了 Linux 中提供的信号量 API。信号量的简单用法是

sem_wait()
   //do something       
sem_post()

可以通过使用 pthread 库中可用的同步原语来实现类似的行为吗?

在通过 POSIX API 之后,我想出了以下代码:

int a = COUNT_LIMIT; //global variable
pthread_mutex_t m1;
pthread_cond_t c1;

 pthread_mutex_lock(&m1);
   while(a==0){
   pthread_cond_wait(&c1, &m1);  
 }
a--;
//do whatever i want to do, as resource is available
pthread_cond_signal(&c1,&m1);
pthread_mutex_unlock(&m1);     

我相信这段代码可以解决问题,但是实现这种行为的最佳实践是什么?

4

1 回答 1

2

您应该只在测试和更改时持有互斥锁a

sem_wait() {
   pthread_mutex_lock(&m1);
   while (a == 0) pthread_cond_wait(&c1, &m1);
   a--;
   pthread_mutex_unlock(&m1);
}
sem_post() {
   pthread_mutex_lock(&m1);
   a++;
   pthread_cond_signal(&c1);
   pthread_mutex_unlock(&m1);
}

真正的问题是,你为什么想要信号量?除非您确实拥有一组真正无法区分的资源,否则互斥锁往往更容易推理,因为它们需要储物柜才能解锁它们。例如,使用互斥锁,您可以通过检测等待图中的循环来进行死锁检测,而对于信号量,您需要使用更复杂的死锁检测算法,例如Dijkstra 的银行家算法

于 2013-08-27T12:42:34.080 回答