美文网首页我爱编程
第4章 锁的优化及注意事项

第4章 锁的优化及注意事项

作者: FaDeo_O | 来源:发表于2018-04-14 11:48 被阅读0次
  1. 提高锁性能的几点建议
    • 减小锁持有时间
    • 减小锁粒度
    • 读写分离锁替换独占锁(读多写少的场景)
    • 锁分离(LinkedBlockingQueue中的putLock,takeLock
    • 锁粗化(适当扩大锁范围,尝试将多次锁操作合并)
  2. Java 虚拟机对锁优化所做的努力
    • 锁偏向,获得锁后就进入偏向模式,再次请求锁时无需任何同步操作,节省大量有关锁申请的操作,适用于几乎没有锁竞争的场合,-XX:+UseBiasedLocking可以开启偏向锁
    • 轻量级锁 。。。
    • 自旋锁,请求锁失败时,为避免直接在操作系统层面挂起,让当前线程做几个空循环,如果依然无法获取才挂起
    • 锁消除,jit编译时进行上下文扫描去除不可能存在资源竞争的锁,逃逸分析是观察某个变量是否会跳出某个作用域,在-server模式下,可以使用-XX:+DoEscapeAnalysis打开逃逸分析。使用-XX:+EliminateLocks可以打开锁消除
  3. ThreadLocal是线程局部变量,只有当前线程可以访问,在Thread对象中持有一个ThreadLocalMap对象,在线程池的场景下,最好使用ThreadLocal.remove()将变量移除,或设为null来防止内存泄露,在一些场景下,比如多线程产生随机数使用ThreadLocal<Random>会获得更好的性能
  4. CAS(Compare And Swap)对死锁天生免疫,线程间的相互影响也远小于基于锁的方式,没有锁竞争带来的系统开销,也咩有线程间频繁调度带来的开销,比基于锁的方式有更优越的性能。CAS(V,E,N)中V标识要更新的变量,E表示预期值,N表示新值。仅当V等于E时,才将V设为N,如果V和E不同,则说明其他线程做了更新,当前线程什么都不做,最后,CAS返回当前V的真实值。多个线程同时使用 CAS 操作一个变量时只有一个会胜出,失败的线程不会被挂起,而是进行失败重试
  5. JDK 中的 atomic 包中实现了一些可直接使用 CAS 操作的线程安全类型,unsafe 中封装了一些和指针相关的操作,属于 JDK 内部使用的专属类。AtomicXXX 类中大量使用了 unsafe 操作
    • AtomicInteger、AtomicLong等对数值封装
    • AtomicReference无锁对象的引用,保证修改对象引用时的线程安全性,但存在的一个问题是只根据对象值,无法根据对象状态,即对象被修改了很多次后值和 CAS 期望值一致
    • AtomicStampedReference维护了对象值和时间戳,更新时对象值和时间戳必须都满足期望值,并且会更新对象值和时间戳
    • AtomicIntegerArray、AtomicLongArray、AtomicReferenceArrayAtomicIntegerArray来说,本质上是对int[]的封装,使用Unsafe类的 CAS 方式控制int[]
    • AtomicIntegerFieldUpdater,AtomicLongFieldUpdater,AtomicReferenceFieldUpdater可以为对象的非privatevolatile成员变量提供线程安全的更新操作

相关文章

  • 《实战高并发程序设计》读书笔记-锁优化的角度

    锁的优化及注意事项 有助于提高”锁“性能的几点建议 减小锁持有时间 应该尽可能地减少对某个锁的占有时间,以减少线程...

  • 第4章 锁的优化及注意事项

    提高锁性能的几点建议减小锁持有时间减小锁粒度读写分离锁替换独占锁(读多写少的场景)锁分离(LinkedBlocki...

  • 2019-06-21 java性能优化细节及编码时注意事项

    java性能优化细节及编码时注意事项

  • 2018-07-16

    图片排名优化的技巧及注意事项 图片排名优化的技巧及注意事项,如下: 1、网站的权重、网站的权威性、网站的年龄,这些...

  • 锁的优化及注意事项(一)

    一、提高锁性能的几点建议 锁的竞争会导致程序整体性能的下降,如何降低锁竞争带来的副作用是我们必须考虑的。下面提出几...

  • 锁的优化及注意事项(二)

    一、无锁 对于并发控制而言,锁是一种悲观的策略,总是假设每一次进入临界区操作都会产生冲突,如果多线程访问临界区资源...

  • 锁的优化及注意事项(1)

    实战Java高并发程序设计笔记 在高并发的环境下,激励的锁竞争会导致程序的性能下降。因为多线程应用除了处理功能需求...

  • A/B测试- 优化产品黑客利器

    一、什么是增长以及如何实现 二、转化率优化(CRO) 三、如何优化转化率 四、优化常见问题及注意事项 五、优化利器...

  • iOS端sqlite3 的线程安全

    sqlite3 多线程和锁 ,优化插入速度及性能优化这篇博客,着重介绍了sqlite3 多线程和锁。这里针对iOS...

  • Android 性能优化(UI渲染)

    注意事项: 布局优化;尽量使用include、merge、ViewStub标签,尽量不存在冗余嵌套及过于复杂布局(...

网友评论

    本文标题:第4章 锁的优化及注意事项

    本文链接:https://www.haomeiwen.com/subject/htqqhftx.html