028-86922220

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

CAS原理与JDK8的优化是什么

CAS原理与JDK8的优化是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

创新互联从2013年开始,先为福山等服务建站,福山等地企业,进行企业商务咨询服务。为福山企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

什么是CAS

CAS-CompareAndSet,是JDK原子变量类AtomicInteger、AtomicLong、AtomicInteger、AtomicBoolean、AtomicReference等实现的基础,例如对于一个共享变量int,就算是简单的自增操作也不是原子性的,多线程同时自增,可能会导致变量的值比预期结果小。但是可以使用AtomicInteger的incrementAndGet() 方法操作变量,这样结果和预期值一样。跟传统的加锁不同,getAndDecrement()方法并没有给代码加锁。代码类似于:

public final int incrementAndGet() {
    for (;;) {
        int current = get();
        int next = current + 1;
        if (compareAndSet(current, next))
            return next;
    }
}

底层通过sun.misc.Unsafe的本地方法compareAndSwapInt实现,这个方法是原子的。

与synchronized的对比

synchronized是阻塞的,CAS更新是非阻塞的,只是会重试,不会有线程上下文切换开销,对于大部分比较简单的操作,无论是在低并发还是高并发情况下,这种乐观非阻塞方式的性能都要远高于悲观阻塞式方式。

应用场景

可能存在的问题

JDK8的优化

JAVA8新增了LongAdder、DoubleAdder对原子变量进行进一步优化,主要是利用了分段CAS的机制,如果不用LongAdder,用AtomicLong的话,在高并发情况下,会产生一直自旋,导致效率不高。他将一个数分成若干个数,CompareAndSet方法的参数只是比较的这若干个数中的一个数,从而降低了自旋的概率,提高了效率。

关于CAS原理与JDK8的优化是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


当前题目:CAS原理与JDK8的优化是什么
地址分享:http://www.tsicrk.com/article/jhjcds.html

其他资讯

让你的专属顾问为你服务

0.7096s