在字节码级别上,Java具有
monitorenter和
monitorexit操作,在Java虚拟机规范的此页中进行了记录,并在下面粘贴了摘录(
objectref 是该操作的操作数,取自堆栈):
监控 代码段
每个对象都有一个与其关联的监视器。执行 monitorenter 的线程 获得与 objectref
关联的监视器的所有权。如果另一个线程已经拥有与 objectref
关联的监视器,则当前线程将等待直到对象被解锁,然后再次尝试获取所有权。如果当前线程已经拥有与 objectref
关联的监视器,则它将在监视器中增加一个计数器,以指示该线程进入监视器的次数。如果与 objectref
关联的监视器不属于任何线程,则当前线程将成为该监视器的所有者,并将此监视器的条目计数设置为1。
监控 退出代码段
当前线程应该是与 objectref
引用的实例相关联的监视器的所有者。该线程递减计数器,以指示其进入此监视器的次数。结果,如果计数器的值变为零,则当前线程释放监视器。如果与
objectref 关联的监视器 变为空闲,则允许等待获取该监视器的其他线程尝试这样做。
因此,“监视器”是答案,NPE答案中未提及的JLS也未指定在本机代码级别上发生的事情。如果您考虑到特定的平台(CPU和操作系统)和特定的JVM实现(包括版本),则当然可以查看JVM源(如果它是开放源JVM),或者在这里询问。
我还从1997年开始访问了这个博客,其中提供了更多详细信息。



