温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java锁的使用方法

发布时间:2021-01-05 10:48:01 来源:亿速云 阅读:178 作者:小新 栏目:编程语言

这篇文章将为大家详细讲解有关Java锁的使用方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

Java锁的使用方法:

1 锁的对象和范围

  • 缩小粒度
    Java锁的使用方法
    Java锁的使用方法

2 锁的对象本身大小

  • 减少空间占用
    Java锁的使用方法
    Atomic long V.S long
    前者是个对象,包含对象头(object header)以保存hashcode、lock 等信息,64 位系统下占16字节,64位系统下:

  • volatile long= 8 bytes

  • AtomicLong = 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
Java锁的使用方法

结论:及时衡量、使用JDK最新的功能

根据不同情况,选择不同的并发包实现

JDK< 1.8考虑ConcurrentHashMapV8 ( ConcurrentHashMap在jDK8中的版本)
Java锁的使用方法

4 不同场景选择不同的并发类

因需而变

  • 关闭和等待关闭事件执行器( Event Executor):
    Object.wait/ notify =》 CountDownLatch
    Java锁的使用方法

  • Nio Event loop中负责存储task的Queue
    Jdk’s LinkedBlockingQueue (MPMC,多生产者多消费者) -> jctools’ MPSC
    io.netty.util.internal.PlatformDependent.Mpsc#newMpscQueue(int):
    Java锁的使用方法
    Java锁的使用方法

5 锁的价值

能不用则不用
Netty应用场景下:局部串行+整体并行>- -个队列+多个线程模式:
降低用户开发难度、逻辑简单、提升处理性能
避免锁带来的上下文切换和并发保护等额外开销

避免用锁:用ThreadLocal来避免资源争用,例如Netty轻量级的线程池实现
Java锁的使用方法

关于“Java锁的使用方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI