打印零与奇偶数

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);
            }
        }
    }
};
上一篇:(转载)java中判断字符串是否为数字的方法的几种方法


下一篇:RT-Thread学习笔记2-互斥量与信号量