一、syn、reentrantLock 性能对比
分析:以上图证明,随着线程数增强sync在下降,但是不能证明sync就是性能低下,分业务场景。
1、如果线程之间竞争不激烈,此时用sync性能较高,并且简单,jvm本身做了优化
2、如果线程之间竞争激烈,就要考虑其他方式。
reentrantLock 使用如果同步时间较长,建议采用公平模式,防止自旋占用cpu,默认非公平
二、应用优化
1、减少锁占用时间
同步代码块中尽量减少无用的信息。
例如:一个同步方法包含n个方法,针对不需要同步的方法,放在同步块之外。减少线程的等待
2、锁颗粒化
例如concurrentHashmap
增大线程的并发量
3、锁分离
例如:linkedblockqueue
采用reentrantLock 针对put、take分别加锁
4、锁粗化
例如一个方法,多次嵌套使用一个锁,不太合适,多次锁的出入也影响性能。凡事都有一个度