代码演示synchronize锁的变化过程

2 篇文章 0 订阅

synchronize 涉及的锁:偏向锁,轻量级锁,重量级锁的相关概念和总结的文章已经很多了,这里推荐两篇我觉得不错的:
锁状态
锁的升级
我把这个变换过程通过代码一起展示下:

//	
//	<dependency>
//			<groupId>org.openjdk.jol</groupId>
//			<artifactId>jol-core</artifactId>
//			<version>0.14</version>
//			<scope>provided</scope>
//	</dependency>
//
public static void main(String[] args) throws InterruptedException {
		Thread.sleep(5000);

		System.out.println(ByteOrder.nativeOrder());
		Test a = new Test();
		System.out.println("init header:" + ClassLayout.parseInstance(a).toPrintable());
		synchronized (a) {
			System.out.println("main first header" + ClassLayout.parseInstance(a).toPrintable());
		}
		Thread t1 = new Thread(
				() -> {
					try {
						Thread.sleep(1);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					synchronized (a) {
						try {
							Thread.sleep(1);
						} catch (InterruptedException e) {
							e.printStackTrace();
						}
						System.out.println("t1 thread header:" + ClassLayout.parseInstance(a).toPrintable());
					}
				});
		Thread t2 = new Thread(
				() -> {
					try {
						Thread.sleep(2);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					synchronized (a) {
						System.out.println("t2 header:" + ClassLayout.parseInstance(a).toPrintable());
					}
				});
		t1.start();
		synchronized (a) {
			System.out.println("main header:" + ClassLayout.parseInstance(a).toPrintable());
		}
		t2.start();
		t2.join();
		System.out.println("no lock header:" + ClassLayout.parseInstance(a).toPrintable());
		synchronized (a) {
			System.out.println("不可降级 header:" + ClassLayout.parseInstance(a).toPrintable());
		}
	}

运行结果:
在这里插入图片描述
这里需要注意下对应机器上的字节序:我这里是LITTLE_ENDIAN。

这里总结下,我看这个过程的一些QA:

  • Q1:为什么初始锁状态为101
  • A1: vm会有4秒的偏向锁开启的延迟时间,在这个偏向延迟内对象处于为无锁态。如果关闭偏向锁启动延迟、或是经过4秒且没有线程竞争对象的锁,那么对象会进入无锁可偏向状态。无锁可偏向状态应该叫做匿名偏向(Anonymously biased)状态,因为这时对象的mark word中后三位已经是101。「可以把代码中开始的thread.sleep 去掉进行对应验证」
  • Q2:Klass Pointer(类型指针) 为什么在64位机器上只占用了4字节,32位
  • A2: 对于64位机器上,是默认开始指针压缩的,目的是减少内存占用,提高效率。因此在这个adress 占32位
  • Q3: 对象结构中对齐填充padding结构如何体现
  • A3:可以在对象结构中增加对应的成员变量 如:int i;long l;等验证这个结构。
  • Q4: 为什么膨胀为重量级锁之后,Klass Pointer 内容不在变化
  • A4: 膨胀为重量级锁之后对应的objectMontior对象不在变化,此时Klass Pointer 内容一致对应monitor对象的地址。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值