1. 程式人生 > >四個執行緒,兩個加減法執行緒對資料加減的排程模擬

四個執行緒,兩個加減法執行緒對資料加減的排程模擬

public class ThreadDemo {
    public static void main(String[] args) throws InterruptedException {
        Resource res = new Resource();
        PlusThread pt = new PlusThread(res);
        MinusThread mt = new MinusThread(res);
        new Thread(pt,"加法A").start();
        new Thread(pt,"加法B").start();
        new Thread(mt,"減法C").start();
        new Thread(mt,"減法D").start();
    }
}
class Resource{
    private int num = 0;
    private boolean flag = true;//加減切換,true表示加,false表示減
    public synchronized void plus() {
        if(this.flag == false) {
            try {
                super.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        try {
            Thread.sleep(100);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        this.num ++;
        System.out.println(Thread.currentThread().getName() + "   num:" + this.num);
        this.flag = false;
        super.notifyAll();//喚醒全部執行緒
    }
    public synchronized void minus() {
        if(this.flag == true) {
            try {
                super.wait();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        try {
            Thread.sleep(100);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        this.num --;
        System.out.println(Thread.currentThread().getName() + "    num:" + this.num);
        this.flag = true;
        super.notifyAll();//
    }
}
class PlusThread implements Runnable{
    private Resource res;
    public PlusThread(Resource res) {
        this.res = res;
    }
    public void pulsR() {
        for(int x = 0;x < 50;x ++) {
            this.res.plus();
        }
    }
    @Override
    public void run() {
        this.pulsR();
    }
}
class MinusThread implements Runnable{
    private Resource res;
    public MinusThread(Resource res) {
        this.res = res;
    }
    public void MinusR() {
        for(int x = 0;x < 50;x ++) {
            this.res.minus();
        }
    }
    @Override
    public void run() {
        this.MinusR();
    }
}
結合資料同步,鎖機制,等待和休眠進行完成