【synchronized关键词】从字节码层面解析

本文详细探讨了Java中synchronized关键字的底层实现,通过monitorenter和monitorexit两条指令来实现锁机制。当monitor进入数为0时,线程获取所有权并进入;若线程已拥有monitor,进入数递增;否则线程将被阻塞,等待monitor释放。monitorexit指令则负责释放monitor,当进入数减至0时,线程退出并释放所有权。了解这一实现原理有助于更好地理解和使用synchronized。
摘要由CSDN通过智能技术生成

java中我们都知道synchronized关键字是用来加锁,在多线程并发情况下实现同步的,那它底层是怎么实现的呢?


代码清单1-1

public class SyncTest {

	public void test(){
		synchronized(this){
			System.out.println("-------call test() method---------");
		}
	}
}

代码清单1-1的字节码(通过javap -c SyncTest 查看字节码)

public class SyncTest {
  public SyncTest();
    Code:
       0: aload_0
       1: invokespecial #1                  // Method java/lang/Object."<init>":
()V
       4: return

  public void test();
    Code:
       0: aload_0
       1: dup
       2: astore_1
       3: monitorenter
       4: getstatic     #2                  // Field java/lang/System.out:Ljava/io/PrintStream;
       7: ldc           #3                  // String -------call test() method---------
       9: invokevirtual #4                  // Method java/io/PrintStream.printl
n:(Ljava/lang/String;)V
      12: aload_1
      13: monitorexit
      14: goto          22
      17: astore_2
      18: aload_1
      19: monitorexit
      20: aload_2
      21: athrow
      22: return
    Exception table:
       from    to  target type
           4    14    17   any
          17    20    17   any
}

注意:synchronized关键词是通过的monitorenter、monitorexit这两条指令来实现同步锁的。


代码清单1-2

public class SyncTest {

	public synchronized void test(){
		System.out.println("-------call test() method---------");
	}
}

代码清单1-2的字节码(通过javap -c SyncTest 查看字节码)

Compiled from "SyncTest.java"
public class SyncTest {
  public SyncTest();
    Code:
       0: aload_0
       1: invokespecial #1                  // Method java/lang/Object."<init>":()V
       4: return

  public synchronized void test();
    Code:
       0: getstatic     #2                  // Field java/lang/System.out:Ljava/io/PrintStream;
       3: ldc           #3                  // String -------call test() method---------
       5: invokevirtual #4                  // Method java/io/PrintStream.println:(Ljava/lang/String;)V
       8: return
}

没有什么特别的指令,那通过javap -verbose可以看到更加清楚的信息


代码清单1-2的字节码(通过javap -verbose SyncTest 查看字节码)

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值