推荐(免费):java基础教程
1 锁的对象和范围
缩小粒度
2 锁的对象本身大小
减少空间占用
atomic long v.s long
前者是个对象,包含对象头(object header)以保存hashcode、lock 等信息,64 位系统下占16字节,64位系统下:volatile long= 8 bytesatomiclong = 8 bytes (volatile long) + 16bytes (对象头) + 8 bytes (引用) = 32 bytes
至少节约24字节!所以 atomic* objects =》 volatile primary type + static atomic*fieldupdater
3 锁的速度
提高并发性
longcounter
记录内存分配字节数等功能用到的。
高并发下: java.util.concurrent.atomic.atomiclong => java.util.concurrent.atomic.longadder
结论:及时衡量、使用jdk最新的功能
根据不同情况,选择不同的并发包实现
jdk< 1.8考虑concurrenthashmapv8 ( concurrenthashmap在jdk8中的版本)
4 不同场景选择不同的并发类
因需而变
关闭和等待关闭事件执行器( event executor):
object.wait/ notify =》 countdownlatch
nio event loop中负责存储task的queue
jdk’s linkedblockingqueue (mpmc,多生产者多消费者) -> jctools’ mpsc
io.netty.util.internal.platformdependent.mpsc#newmpscqueue(int):
5 锁的价值
能不用则不用
netty应用场景下:局部串行+整体并行>- -个队列+多个线程模式:
降低用户开发难度、逻辑简单、提升处理性能
避免锁带来的上下文切换和并发保护等额外开销
避免用锁:用threadlocal来避免资源争用,例如netty轻量级的线程池实现
以上就是一起和netty学习java锁的使用的详细内容。
