当我在某个地方变红时,当我们有同步方法时,只有一个线程可以同时使用这些方法中的任何一个。问题是我有一些小的代码可以打破这个规则,我希望你们中的一些人知道原因。
import java.util.Date;
public class SyncTest extends Thread {
private int state;
public static final int STATE_STOP = 10;
public static final int STATE_DO_TASK = 2;
public static final int STATE_FREE = 0;
public void run() {
try {
while(getThisState() != STATE_STOP) {
if(getThisState() == STATE_DO_TASK) {
Thread.sleep(2000);
setState(0);
}
}
}catch(Exception ex) {
ex.printStackTrace();
}
}
public synchronized void setState(int newState) {
this.state = newState;
this.notify();
}
public synchronized int getThisState() {
return this.state;
}
public synchronized void waitForComplete(int timeoutMilisec) {
try {
while( getThisState() != STATE_FREE) {
wait(timeoutMilisec);
}
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public static void main(String[] args) {
SyncTest syncTest = new SyncTest();
syncTest.start();
syncTest.setState(STATE_DO_TASK);
System.out.println("Start operation: " + new Date());
syncTest.waitForComplete(30000);
syncTest.setState(STATE_STOP);
System.out.println("End operation: " + new Date());
}
}
我们这里有的是“等待完成”'等待状态等于零的方法。当主线程等待时,第二个线程正在休眠5秒,然后调用setState方法。这改变了状态'变量为零,并且调用通知在主进程中等待解锁的内容。这似乎是有道理的,但问题是:第二个线程如何执行' setState'当同时主线程在内部' waitForComplete'方法。两种方法都是同步的,因此不可能同时执行它们。
答案 0 :(得分:4)
当您调用wait()
时,线程会在监视器上释放其锁定,因此其他线程可以自由进入同步块。