1 题目
假设有这么一个类:
class ZeroEvenOdd {
public ZeroEvenOdd(int n) { ... } // 构造函数
public void zero(printNumber) { ... } // 仅打印出 0
public void even(printNumber) { ... } // 仅打印出 偶数
public void odd(printNumber) { ... } // 仅打印出 奇数
}相同的一个 ZeroEvenOdd 类实例将会传递给三个不同的线程:
线程 A 将调用 zero(),它只输出 0 。
线程 B 将调用 even(),它只输出偶数。
线程 C 将调用 odd(),它只输出奇数。
每个线程都有一个 printNumber 方法来输出一个整数。请修改给出的代码以输出整数序列 010203040506... ,其中序列的长度必须为 2n。
2 代码(信号量)
#include <semaphore.h>
class ZeroEvenOdd {
private:
int n;
protected:
sem_t zeroDone;
sem_t evenDone;
sem_t oddDone;
public:
ZeroEvenOdd(int n) {
this->n = n;
sem_init(&zeroDone, 0, 1);
sem_init(&evenDone, 0, 0);
sem_init(&oddDone, 0, 0);
}
// printNumber(x) outputs "x", where x is an integer.
void zero(function<void(int)> printNumber) {
for(int i = 1; i <= n; i++) {
sem_wait(&zeroDone);
printNumber(0);
if(i&1){
sem_post(&oddDone);
}else{
sem_post(&evenDone);
}
}
}
void even(function<void(int)> printNumber) {
for(int i = 1; i <= n; i++){
if(i&1){
}else{
sem_wait(&evenDone);
printNumber(i);
sem_post(&zeroDone);
}
}
}
void odd(function<void(int)> printNumber) {
for(int i = 1; i <= n; i++){
if(i&1){
sem_wait(&oddDone);
printNumber(i);
sem_post(&zeroDone);
}
}
}
};