Java并发编程——锁粗化(Lock Coarsening)和锁消除(Lock Eliminate)

锁粗化(Lock Coarsening)

核心思想

一般来说,同步块的作用范围应该尽可能小,缩短阻塞时间,如果存在锁竞争,那么等待锁的线程也能尽快获取锁

但某些情况下,可能会对同一个锁频繁访问,为了降低短时间内大量的锁请求、释放带来的性能损耗,应适当的将锁的作用范围扩大(粗化),将多个锁请求合并为一个请求

示例

public class LockCoarsening {
	public String test() {
		StringBuffer sb = new StringBuffer();
		for(int i = 0; i < 100; i++) {
			sb.append("喵");
		}
		return sb.toString();
	}
}

append() 为同步方法,短时间内大量进行锁请求、锁释放,JVM 会自动进行锁粗化,将加锁范围扩大至 for 循环外部,从而只需要进行一次锁请求、锁释放


锁消除(Lock Eliminate)

即时编译器

当 JVM 发现某个方法或代码块频繁被执行时,会将其标记为热点代码(Hot Spot Code),为了提高热点代码的执行效率,在运行时,虚拟机将会把这些热点代码编译成与本地代码相关的机器码,并进行各层次的深度优化,这些优化操作由即时编译器(Just In Time Compiler)完成


核心思想

即时编译器通过对运行上下文的扫描,对不可能存在共享资源竞争的锁进行消除,从而节约大量的资源开销,提高效率


示例

public class LockEliminate {
	static int x = 0;

	public void method1() {
		x++;
	}

	public void method2() {
		Object obj = new Object();
		synchronized (obj) {
			x++;
		}
	}
}

method2() 方法中的 obj 为局部变量,显然不可能被共享,对其加锁也毫无意义,故被即时编译器消除

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值