【java线程】锁的优化

一、是否选择锁

如果不存在多个线程操作共享变量,那么根本就无需锁

二、是否可以选择ThreadLocal

如果能用这个类解决,那么首先考虑这个。使用场景

三、乐观锁

乐观锁的核心就是自旋。现在很多类都是这个机制,AtomicXXX类的基本都是乐观锁的实现。
他的适用场景是锁的竞争不是很激烈的情况。

四、Synchronize可重入锁

这类锁会导致线程从用户态切换到内核态,所以是重量级锁。但是自从1.5之后synchronize关键字已经优化了好多,现在基本和ReentrentLock性能一致

4.1 Synchronize语义

他的实现核心是 monitorenter 和monitorexit指令。如果是liunx其实就是调用pthread来完成这些操作

4.2 锁的粗化

StringBuffer sb = new StringBuffer();
sb.append("1");
sb.append("2");

虽然StringBuffer 的方法都是被synchronize修饰,但是虚拟机会进行优化,其实就一次加锁

4.3 锁的消除

这个就必须说到对象逃逸:某个对象在方法内创建,并且并没有在返回结果中返回出去,就可以理解这个对象没有发生逃逸。
如果锁是没有逃逸的对象,那么完全可以锁消除

4.4 锁的自旋

一旦某个线程没有获取到锁,他不是直接就挂起,而是先不停的休眠,然后尝试,知道超过一定时间或者次数才会把自己挂起。

4.4 偏向锁、轻量级锁、重量级锁

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值