对于jdk并发包的理解(一)
名词解释
CAS操作 : 原子操作
32位IA-32处理器使用基于对缓存加锁或总线加锁的方式来实现多处理器之间的原子操作,
当一个处理器读取一个字节时,其他处理器不能访问这个字节的内存地址。(引入自CAS操作详解感谢)
位置
展开jdk后 rt.jar下java->util->concurrent包(java11更换到java.base->java->util->concurrent包)
concurrent下包含三部分,第一部分原子类包(atomic),第二部分和锁相关包(locks),第三部分concurrent本身包含的类
atomic(原子类包)
以AtomicBoolean为例
静态代码块部分获取“起始地址”偏移量
getDeclaredFiled 仅能获取类本身的属性成员(包括私有、共有、保护),此处获取了value
unsafe…objectFieldOffset()方法用于获取某个字段相对Java对象的“起始地址”的偏移量
unsafe.compareAndSwapInt方法的作用是,读取传入对象在内存中偏移量为offset位置的值与期望值expected作比较:
相等就把x值赋值给offset位置的值。方法返回true。
不相等,就取消赋值,方法返回false。
在JDK8乃至之前的版本,weakCompareAndSet方法并没有被真是意义上的实现,目前该方法所呈现出来的效果与compareAndSet方法是一样的(only rarely an appropriate alternative)
Striped64
个人理解是对原子类进行的一系列操作(如果有大佬对这块理解的比较透彻请评论区戳我–使劲戳我,感激不尽 )
这一部分,个人理解是对外的使用方法等(如果有大佬对这块理解的比较透彻请评论区戳我–使劲戳我,感激不尽 )
其他部分请看整理的其他文档