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方法也会被叫醒