- 博客(3)
- 收藏
- 关注
原创 ConurrentHashMap底层原理
java容器类Map有多种实现,如HashMap、HashTable和ConcurrentHashMap。其中,在并发场景下,HashMap实现的操作,诸如put、remove等方法都是线程不安全的,除此之外,hashMap在扩容时可能出现循环链表等问题。
2023-08-27 00:35:05
161
1
原创 并发编程-可见性
可见性问题是在并发场景下,对共享资源进行读写操作而产生。JMM规定所有的共享变量都存放在主存,线程使用变量时,会将变量加载到自己的工作内存中,线程对变量的读写操作都是在自己的工作内存中。主存和工作内存从图中不难发现,线程A将sum修改为1时,线程B的工作内存中依然是1,对于线程B来说,线程A的操作对线程B来说就是不可见。在java中,要想实现变量的可见性,可以通过volatile修饰。MESI协议是以缓存行的4种状态的首字母缩写来命名的。
2023-08-26 20:30:03
107
原创 聊聊CAS
Unsafe类的全限定名为sun.misc.Unsafe,提供大量native方法,基于c++实现,这些方法在提升Java运行效率、增强Java语言底层资源操作能力方面起到了很大的作用。而java应用层就是通过调用Unsafe类中的方法,以此实现CAS操作,保证临界区的原子性。那么应用层如何调用,以及调用Unsafe类中的那些方法来实现CAS操作呢?获取Unsafe实例获取字段的偏移量调用Unsafe中的cas方法。
2023-08-20 13:56:43
187
1
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人
RSS订阅