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是否相同。如果相同,代表是自己获取的锁,直接进入。如果不相同,则代表是其他的线程获取了偏向锁,需要判断锁对象是否处于锁状态

  • 相关阅读:
    php八种常用函数
    已知二叉树的前序中序遍历,如何得到它的后序遍历?
    PTA_Have fun with numbers(C++)
    PTA_输入符号及符号个数打印沙漏(C++)
    Web安全之SQL注入
    南京邮电大学//bugkuCTF部分writeup
    修改或添加HTTP请求头
    第二次作业
    博客作业1
    linux python 串口
  • 原文地址:https://www.cnblogs.com/yfdream/p/8487362.html
Copyright © 2011-2022 走看看