![](https://img-blog.csdnimg.cn/20201014180756928.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
JUC
文章平均质量分 55
da297368860
这个作者很懒,什么都没留下…
展开
-
J.U.C-4.CAS机制
CAS机制 CAS(Compare And Swap,即比较并交换),是解决多线程并行情况下使用锁造成性能损耗的一种机制。其原理是利用sun.misc.Unsafe.java 类通过JNI来调用硬件级别的原子操作来实现CAS(即CAS是借助C来调用CPU底层指令实现的)。 CAS机制=比较并交换+乐观锁机制+锁自旋 设计思想:如果内存位置 的值与 预期原值 相匹配,那么处理器会自动将该位置值更新为新值,否则处理器不做任何操作。 ReentrantLock、ReentrantReadWriteLock 都是基原创 2021-11-11 16:53:33 · 392 阅读 · 0 评论 -
J.U.C-3.LockSupport
LockSupport LockSupport 和 CAS 是Java并发包中很多并发工具控制机制的基础,它们底层其实都是依赖Unsafe实现。LockSupport 提供park()和unpark()方法实现阻塞线程和解除线程阻塞。 LockSupport和每个使用它的线程都与一个许可(permit)关联。permit相当于1,0的开关,默认是0,调用一次unpark就加1变成1,调用一次park会消费permit, 也就是将1变成0,同时park立即返回。再次调用park会变成block(因为permi原创 2021-11-11 16:48:35 · 821 阅读 · 0 评论 -
J.U.C-2.Unsafe
Unsafe Java不能直接访问操作系统底层,而是通过本地方法来访问。Unsafe类提供了硬件级别的原子操作,主要提供以下功能: 通过Unsafe类可以分配内存,可以释放内存 类中提供的3个本地方法allocateMemory(申请)、reallocateMemory(扩展)、freeMemory(销毁)分别用于分配内存,扩充内存和释放内存,与C语言中的3个方法对应。 可以定位对象某字段的内存位置,也可以修改对象的字段值,即使它是私有的 字段的定位 数组元素定位 挂起与恢复 将一个线程进行原创 2021-11-11 16:44:50 · 415 阅读 · 0 评论 -
J.U.C-1.并发特性
J.U.C 并发特性 JAVA里面进行多线程通信的主要方式就是 共享内存 的方式,共享内存主要的关注点有两个:可见性 和 有序性。加上复合操作的 原子性,可以认为JAVA的线程安全性问题主要关注点有3个(JAVA内存模型JMM解决了可见性和有序性的问题,而锁解决了原子性的问题):可见性、有序性、原子性 原子性(Atomicity):在Java中原子性指的是一个或多个操作要么全部执行成功要么全部执行失败 有序性(Ordering):程序执行的顺序按照代码的先后顺序执行(处理器可能会对指令进行重排序) 可见性原创 2021-11-11 15:32:55 · 841 阅读 · 0 评论