Linux下利用条件变量实现信号量机制

接上一篇《Linux下利用条件变量实现读写锁》,继续讨论如何利用pthread_cond_t来实现sem_t。目前的Linux内核都支持信号量sem_t,但也有一些老的OS,如AIX4,和早期的Solaris并不支持信号量,毕竟semaphore这个东东并没有包括在POSIX标准里。这种情况下有必要利用pthread_mutex_t + pthread_cond_t来模拟semaphore啦。(什么?pthread_mutex_t pthread_cond_t也不支持? !@#¥%!)

其实实现起来真的很简单,

class Semaphore {

protected:

pthread_mutex_t mutex;

pthread_cond_t cond;

unsigned int waiters;

public:

Semaphore();

virtual ~Semaphore() {}

int p();

int v();

}

Semaphore::Semaphore() {

mutex = PTHREAD_MUTEX_INITIALIZER;

cond = PTHREAD_COND_INITIALIZER;

waiters = 0;

}

int Semaphore::p() {

pthread_mutex_lock(&mutex);

while (waiters <= 0) {

pthread_cond_wait(&cond, &mutex);

}

waiters--;

pthread_mutex_unlock(&mutex);

}

int Semaphore::v() {

pthread_mutex_lock(&mutex);

waiters++;

if (waiters > 0) {

pthread_cond_signal(&cond);

}

pthread_mutex_unlock(&mutex);

}

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/24455.html