【发布时间】:2021-09-16 06:59:24
【问题描述】:
我有以下代码,其中多个线程正在调用由静态对象保护的相同实例方法
package com.data;
class TestThread {
private final static Object object = new Object();
public void myWaitMethod() {
synchronized (object) {
System.out.println("Before a " + Thread.currentThread().getId());
try {
object.wait();
} catch (Exception ignore) {
System.out.println(Thread.currentThread().getId());
}
System.out.println("After a " + Thread.currentThread().getId());
}
}
public void myNotifyMethod() {
synchronized (object) {
System.out.println("Before Notify");
object.notifyAll();
System.out.println("After b");
}
}
public static void main(String[] args) throws InterruptedException {
TestThread aa1 = new TestThread();
new Thread(() -> aa1.myWaitMethod()).start();
new Thread(() -> aa1.myWaitMethod()).start();
Thread.sleep(1000);
System.out.println("sleep");
Thread.sleep(1000);
aa1.myNotifyMethod();
}
}
o/p:
Before a 12
Before a 13
sleep
Before Notify
After b
After a 13
After a 12
我不明白为什么“Before a”会打印两次,即使块已同步。
【问题讨论】:
标签: java synchronization