• 加锁和释放锁的原理


    加锁和释放锁的原理

      当方法执行完后或者抛出异常后,都会释放锁

    method1等价于method2,因为method1执行完以后会自动释放锁,而么method2使用lock.unlock()释放锁

    反编译看monitor指令

    被 synchronized 关键字修饰的方法、代码块,就是 monitor 机制的临界区

    进入锁和释放锁是基于monitor来实现的 同步方法和同步代码块,monitor有两个指令,monitorenter会插入到同步代码块的位置,monitorexit会插入到方法块结束和退出的时候,可能有多个monitorexit对应一个monitorenter,因为退出可以是方法结束或者抛出异常

    通过反编译(把.class文件转为.java)

    编译:

    反编译:

    Monditorenter和Monditorexit

    实际上一个对象和一个monitor相关联,一个monitorde lock锁只能被一个线程再同一时间获得

    Monditorenter的三种情况

     1.当monitor计数器为0,代表没有被获得,然后线程立马获得该Monitor,并把计数器加1,当别的线程想进来,但是看到计数器为1,就代表已经被其他线程占有,就只有等待

    2.如果Monitor已经拿到了锁的所有权,又重入了锁,则monitor会累加

    3.如果monitor被其他线程占用了,当我想去获取的时候,不能获取到,只能处于阻塞状态,当计数器为0才能再次尝试去获取锁

    Monditorexit的作用是释放锁,前提是要先拥有此锁,原理是将计数器减1,减1如果monitor为0,则对象不再拥有对锁的所有权,就是解锁,如果不是1,则证明是重入进来的,继续持有锁,

    可重入原理

     可见性原理

     

    生命不止,折腾不息
  • 相关阅读:
    P168 实战练习(权限修饰符)
    Java—面向对象—权限修饰符及思维导图
    P168 实战练习(构造方法)
    Java—面向对象—构造方法及相关思维导图
    面向对象编程(OOP)
    随堂练习——猜生日
    正则表达式
    P141 实战练习——字符串(修改后)
    java经典问题
    java开发环境
  • 原文地址:https://www.cnblogs.com/steakliu/p/10657547.html
Copyright © 2020-2023  润新知