线程之间通信之join应用与实现原理剖析


public class Demo {

    public void a(Thread joinThread) {

        System.out.println("方法a执行了...");
        joinThread.start();
        try {
            joinThread.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("a方法执行完毕...");

    }

    public void b() {
        System.out.println("加塞线程开始执行....");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("加塞线程执行完毕...");
    }

    public static void main(String[] args) {
        Demo demo = new Demo();
        Thread joinThread = new Thread(new Runnable() {

            @Override
            public void run() {
                demo.b();
            }
        });

        new Thread(new Runnable() {

            @Override
            public void run() {
                demo.a(joinThread);
            }
        }).start();
    }

}

上面代码中因为是a方法调用join方法、所以synchronized的wait方法是其实锁的东西是a方法,锁的线程是调用a方法的线程,在线程结束的时候会调用自身的notifyAll方法、也就是说当我们的join方法执行完毕的时候会调用notifyAll,notifyAll会叫醒自身的、而我们也发现他们用的同步监视器就是自身的、所以a方法也会被叫醒
线程之间通信之join应用与实现原理剖析_第1张图片

你可能感兴趣的:(Java并发编程)