zoukankan      html  css  js  c++  java
  • java synchronized 关键字的锁升级过程

    java在new一个对象之后,堆中开辟的内存包括3块内容:对象头,对象成员数据,对齐数据。

    如果对象是非数组类型,则对象头有2个Word(字宽,32bit 或 64bit)。

    如果对象是数组类型,则对象头有3个Word。前2个Word和非数组类型相同,第三个word是数组的长度。

    对象头的第二个Word是指向方法区中对象类型的指针。

    对象头的第一个Word叫的Mark Word,是实现偏向锁和轻量级锁的关键。

    Mark Word中的最后2个bit是锁标志位(无锁01,偏向锁01,轻量级锁00,重量级锁10,GC标记11),倒数第三个是偏向锁标志位(0表示无锁,1表示偏向锁)。


    (以下内容是自己瞎猜的)

    当一个线程访问同步块并尝试获取锁时,首先检查锁标志位。

    如果是10,代表已经有重量级锁了,只能wait。

    如果是01,则检查偏向锁标志位。如果是0,代表无锁,则把自己的线程ID写到Mark Word中,然后将偏向锁标志位改为1。如果是1,代表有锁,检查下Mark Word中的线程ID和自己的线程ID是否相同。如果相同,代表是自己获取的锁,直接进入。如果不相同,则代表是其他的线程获取了偏向锁,需要判断锁对象是否处于锁状态

  • 相关阅读:
    js制作倒计时
    SpringBoot tomcat 上传文件大小受限制1M,解决办法
    SQL关于not,exists说法,以及差异
    SQL语句关于树查询
    树(Tree)形插件
    python之函数用法fromkeys()
    模块
    补充零散知识
    pickle模块
    python中元组与列表的区别
  • 原文地址:https://www.cnblogs.com/yfdream/p/8487362.html
Copyright © 2011-2022 走看看