新津县建设局网站,搜狗网站提交入口,一般做推广网站的客户需求仕什么,陕西专业网站开发多少钱问题分析与思考#xff1a; CAS 是 Java 中 Unsafe 类里面的方法#xff0c;它的全称是 CompareAndSwap#xff0c;比较并交换 的意思。 它的主要功能是能够保证在多线程环境下#xff0c;对于共享变量的修改的原子性。 举个例子#xff0c;比如说有这样一个场景#xff… 问题分析与思考 CAS 是 Java 中 Unsafe 类里面的方法它的全称是 CompareAndSwap比较并交换 的意思。 它的主要功能是能够保证在多线程环境下对于共享变量的修改的原子性。 举个例子比如说有这样一个场景如图有一个成员变量 state默认值是 0 定义了一个方法 doSomething()这个方法的逻辑是判断 state 是否为 0 如果为 0就修改成 1。 这个逻辑看起来没有任何问题但是在多线程环境下会存在原子性的问题因为这里 是一个典型的Read - Write 的操作。 一般情况下我们会在 doSomething()这个方法上加同步锁来解决原子性问题。 但是加同步锁会带来性能上的损耗。所以对于这类场景我们就可以使用 CAS 机制来进行优化。如下图所示。 在 doSomething()方法中我们调用了 unsafe 类中的 compareAndSwapInt()方法来 达到同样的目的这个方法有四个参数 分别是当前对象实例、成员变量 state 在内存地址中的偏移量、预期值 0、期望更改 之后的值 1。 CAS机制会比较 state 内存地址偏移量对应的值和传入的预期值 0 是否相等如果相等 就直接修改内存地址中 state 的值为 1.否则返回 false表示修改失败而这个过程是原子的不会存在线程安全问题。 CompareAndSwap 是一个 native 方法实际上它最终还是会面临同样的问题就是 先从内存地址中读取 state 的值然后去比较最后再修改。 这个过程不管是在什么层面上实现都会存在原子性问题。 所以呢CompareAndSwap 的底层实现中在多核 CPU 环境下会增加一个 Lock 指令对缓存或者总线加锁从而保证比较并替换这两个指令的原子性。
结尾 CAS 主要用在并发场景中比较典型的使用场景有两个。 1. 第一个是 JUC 里面 Atomic 的原子实现比如 AtomicIntegerAtomicLong。 2. 第二个是实现多线程对共享资源竞争的互斥性质 比如在 AQS、 ConcurrentHashMap、ConcurrentLinkedQueue 等都有用到。