CAS(Compare and swap) 意思比较并交换。
CAS包含三个操作数: 内存位置V,预期值A, 新值B,如果内存位置的值与期望的值相同,那么就设置为新值。CAS从硬件层面保证了原子性。 UNSafe这个提供了这类原子操作。
java并发包中java.util.concurrent 大量使用了这种操作,来保证线程安全。
比如:
* 比较obj的offset处内存位置中的值和期望的值,如果相同则更新。此更新是不可中断的。
*
* @param obj 需要更新的对象
* @param offset obj中整型field的偏移量
* @param expect 希望field中存在的值
* @param update 如果期望值expect与field的当前值相同,设置filed的值为这个新值
* @return 如果field的值被更改返回true
compareAndSwapInt(Object obj, long offset, int expect, int update);
获取offset偏移量,UNSafe也提供了相应的方法:
比如: objectFieldOffset()
volatile保证了变量的原子性,但并不保证一致性。
Java为了保证在不同的设备上能正常运行,规定了自己的内存模型。 Java内存模型中规定所有的变量都存在主存当中,每个线程都有自己的工作内存,线程所有的操作都在自己的工作内存中进行,然后写到主存中。
volatile关键字的作用是保证不同的线程对这个变量的可见性,
意思是 1. 被Volatile修饰的变量如果发生了改变,会被立即强制写到主存
2. 假如线程1对变量进行了修改,会导致线程2中的这个变量无效,那么线程2如果要使用这个变量就必须去主存中重新读取
3. 不得进行指令重排序
4. 不保证原子性的意思,比如最简单的i++这个操作,其实分为三步,读取,加1,写入工作内存,但是这个过程中比如读取了之后线程被阻塞了,第二个线程进行了修改,那么这个时候是不能保证i的正确性的,如果要保证其正确性就要用加同步锁
欢迎关注我的公众号: manong_xiaodong或扫一扫下面的二维, 有大数据资料赠送哟,因为我最近也在学习大数据!欢迎一起学习!