有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java为什么不同的线程输入了两次“synchronized(lock)”?

在这个简单的例子中,我有两个synchronized (theLock)被不同的线程访问

public class Main {

    public static void main(String[] args) throws InterruptedException {
        System.out.println("start");

        final Object theLock = new Object();

        synchronized (theLock) {
            System.out.println("main thread id : " + Thread.currentThread().getId());

            new Thread(() -> {
                System.out.println("new thread id : " + Thread.currentThread().getId() + ". Inside thread");

                // before entering this section new thread should be blocked as `theLock` is already acquired
                synchronized (theLock) {
                    System.out.println("inside synchronized");
                    theLock.notify();
                }
            }).start();

            theLock.wait();
        }

        System.out.println("end");
    }
}

为什么新创建的线程可以访问内部的synchronized (theLock)部分?据我所知,theLock已经被主线程获取,新线程应该永远阻塞。相反,我看到它也进入了synchronized

这是一个输出

start
main thread id : 1 
new thread id : 13. Inside thread
inside synchronized
end

共 (1) 个答案

  1. # 1 楼答案

    wait()的调用将释放锁Per ^{} Javadoc(加粗我的):

    Causes the current thread to wait until another thread invokes the notify() method or the notifyAll() method for this object. In other words, this method behaves exactly as if it simply performs the call wait(0).

    The current thread must own this object's monitor. The thread releases ownership of this monitor and waits until another thread notifies threads waiting on this object's monitor to wake up either through a call to the notify method or the notifyAll method. The thread then waits until it can re-obtain ownership of the monitor and resumes execution.