4种锁,并发量不是特别大且最稳定是内置synchronized锁(并不是完全被替代),当并发量大且读远大于写的情况下最快的的是StampedLock锁(乐观读。近似于无锁)。建议大家采用。
1)synchronized:重入锁同步锁--适用于并发量不是特别大的情况下,性能中等且稳定
2)ReentrantLock:可重入互斥锁,分为“公平锁”和“非公平锁”。--性能中等,建议需要手动操作线程时使用
3)ReentrantReadWriteLock: 可重入读写锁(并发读、互斥写,但读锁会阻塞写锁,是悲观锁的策略)--适用于读多写少的情况
4)StampedLock:三种模式(排它写,悲观读,乐观读)--适用于当高并发下且读远大于写时,由于可以乐观读,性能极高!
5)valotile是修饰变量的关健字,其他是代码块或方法
1)可重入性:Synchronized是在JVM层面上实现的,无需显示的加解锁,所以随便重入,不会锁读;
ReadWriteLock也是重入性;StampedLock是必须要先释放入能锁的,容易锁读(附它返回值是long类型,意义不大)。
2)ReentrantReadWriteLock

本文深入解析了Java中四种锁的特点及适用场景:synchronized适用于并发量适中的情况;ReentrantLock提供更灵活的锁定机制;ReentrantReadWriteLock优化读多写少的场景;StampedLock在高并发读远大于写时性能卓越。
623

被折叠的 条评论
为什么被折叠?



