0
点赞
收藏
分享

微信扫一扫

Hadoop的第二个核心组件:MapReduce框架第四节

Java——》synchronized的原理

    snchronized是基于对象实现的(JVM——》Java对象内存模型),通过在对象头设置标记,达到了获取锁和释放锁的目的。


    synchronized 是由JVM实现的互斥同步的一种方式(Java——》synchronized互斥性)。查看被synchronized 修饰过的程序块编译后的字节码,会发现在编译前后被编译器生成了monitorentermonitorexit 两个字节码指令(Java——》synchronized编译)。

  1. 在虚拟机执行到monitorenter 指令时,首先要尝试获取对象的锁。如果这个对象没有锁定,或者当前线程已经拥有了这个对象的锁,把锁的计数器+1。如果获取对象失败了,那当前线程就要阻塞等待,直到对象锁被另外一个线程释放为止。
  2. 当虚拟机执行到monitorexit 指令时,将锁的计数器-1。 当计数器为0时,锁就被释放了。
举报

相关推荐

0 条评论