Java使用synchronized或wait和notify实现

2020-06-03  本文已影响0人  _灯火阑珊处
不太好的方法:用synchronized实现
当其中一个线程一直持有锁时,会重复执行 if 判断,做无用功!
/**
 * 两个线程交替打印0-100的奇偶数,
 * 用synchronized关键字实现
 */
public class WaitNotifyPrintOddEvenSyn {

    // 新建2个线程
    // 1个只处理偶数,第二个只处理奇数(用位运算)
    // 用synchronized来通信

    private static int count;

    private static final Object lock = new Object();

    public static void main(String[] args) {
        new Thread(new Runnable() {
            @Override
            public void run() {
                while (count < 100) {
                    synchronized (lock) {
                        if ((count & 1) == 0) {
                            System.out.println(Thread.currentThread().getName() + ":" + count++);
                        }
                    }
                }
            }
        }, "偶数线程").start();

        new Thread(new Runnable() {
            @Override
            public void run() {
                while (count < 100) {
                    synchronized (lock) {
                        if ((count & 1) == 1) {
                            System.out.println(Thread.currentThread().getName() + ":" + count++);
                        }
                    }
                }
            }
        }, "奇数线程").start();
    }
}

更好的实现方法:用wait和notify实现
/**
 * 两个线程交替打印0-100的奇偶数,
 * 用wait和notify实现
 */
public class WaitNotifyPrintOddEvenWait {

    // 1.拿到锁,就打印
    // 2.打印完,唤醒其它线程,自己休眠

    private static int count = 0;

    private static final Object lock = new Object();

    static class TurningRunner implements Runnable {

        @Override
        public void run() {
            while (count <= 100) {
                synchronized (lock) {
                    System.out.println(Thread.currentThread().getName() + ":" + count++);
                    lock.notify();
                    if (count <= 100) {
                        try {
                            lock.wait();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
                }
            }
        }
    }

    public static void main(String[] args) {
        new Thread(new TurningRunner(), "偶数线程").start();
        new Thread(new TurningRunner(), "奇数线程").start();
    }
}

上一篇 下一篇

猜你喜欢

热点阅读