同步方法中有多个线程?

时间:2014-08-13 22:36:33

标签: java multithreading synchronized

当我在某个地方变红时,当我们有同步方法时,只有一个线程可以同时使用这些方法中的任何一个。问题是我有一些小的代码可以打破这个规则,我希望你们中的一些人知道原因。

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'方法。两种方法都是同步的,因此不可能同时执行它们。

1 个答案:

答案 0 :(得分:4)

当您调用wait()时,线程会在监视器上释放其锁定,因此其他线程可以自由进入同步块。