JDK8中引入了高性能的读写锁StampedLock,它的核心思想在于,在读的时候如果发生了写,应该通过重试的方式来获取新的值,而不应该阻塞写操作。这种模式也就是典型的无锁编程思想,和CAS自旋的思想一样。这种操作方式决定了StampedLock在读线程非常多而写线程非常少的场景下非常适用,同时还避免了写饥饿情况的发生。
来自 <https://www.cnblogs.com/konck/p/9691538.html>
随着原生的Synchronized 不断优化,如上文测试那样大部分场景下它的性能都接近甚至超越读写锁。不过要注意这些优化都有个前提就是大部分场景下线程同步区执行时间很短,乐观锁不会升级为悲观锁,所以它能有很好的性能,如果在特殊场景每次锁都会升级为重量级锁性能反而会更差些。正如StampedLock对读写锁的改进一样,如果在某些场景CAS自旋不成功,它性能反而会更差。
读写锁的应用场景可参考下面这个测试说明,