Atomic long V.S long 前者是个对象,包含对象头(object header)以保存hashcode、lock 等信息,64 位系统下占16字节,64位系统下:
所以 Atomic* objects =》 Volatile primary type + Static Atomic*FieldUpdater
提高并发性
记录内存分配字节数等功能用到的。 高并发下: java.util.concurrent.atomic.AtomicLong => java.util.concurrent.atomic.LongAdder
结论:及时衡量、使用JDK最新的功能
JDK< 1.8考虑ConcurrentHashMapV8 ( ConcurrentHashMap在jDK8中的版本)
因需而变
能不用则不用 Netty应用场景下:局部串行+整体并行>- -个队列+多个线程模式: 降低用户开发难度、逻辑简单、提升处理性能 避免锁带来的上下文切换和并发保护等额外开销
避免用锁:用ThreadLocal来避免资源争用,例如Netty轻量级的线程池实现