条件变量与管程
介绍
结构体
typedef struct condvar{
// 信号量
semaphore_t sem;
// 正在等待的线程数
int count;
// 自己属于哪一个管程
monitor_t * owner;
} condvar_t;等待唤醒
实现
最后更新于
typedef struct condvar{
// 信号量
semaphore_t sem;
// 正在等待的线程数
int count;
// 自己属于哪一个管程
monitor_t * owner;
} condvar_t;最后更新于
// wait
cv.count++;
if(monitor.next_count > 0)
sem_signal(monitor.next);
else
sem_signal(monitor.mutex);
sem_wait(cv.sem);
cv.count -- ;// signal
if( cv.count > 0) {
monitor.next_count ++;
sem_signal(cv.sem);
sem_wait(monitor.next);
monitor.next_count -- ;
}typedef struct monitor{
// 保证管程互斥访问的信号量
semaphore_t mutex;
// 里面放着正在等待进入管程执行的进程
semaphore_t next;
// 正在等待进入管程的进程数
int next_count;
// 条件变量
condvar_t *cv;
} monitor_t;monitor dp
{
enum {THINKING, HUNGRY, EATING} state[5];
condition self[5];
void pickup(int i) {
state[i] = HUNGRY;
test(i);
if (state[i] != EATING)
self[i].wait_cv();
}
void putdown(int i) {
state[i] = THINKING;
test((i + 4) % 5);
test((i + 1) % 5);
}
void test(int i) {
if ((state[(i + 4) % 5] != EATING) &&
(state[i] == HUNGRY) &&
(state[(i + 1) % 5] != EATING)) {
state[i] = EATING;
self[i].signal_cv();
}
}
initialization code() {
for (int i = 0; i < 5; i++)
state[i] = THINKING;
}
}