中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Java中cas實現(xiàn)原理是什么

本篇內(nèi)容介紹了“Java中cas實現(xiàn)原理是什么”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序設(shè)計、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了費縣免費建站歡迎大家使用!

java提供了三個CAS操作不安全:

compareAndSwapLong compareAndSwapObject compareAndSwapInt () () ()

//Parameter meaning: object, attribute memory offset, attribute expected value, attribute update valuepublic final native boolean compareAndSwapObject(Object var1, long var2, Object var4, Object var5);public final native boolean compareAndSwapInt(Object var1, long var2, int var4, int var5);public final native boolean compareAndSwapLong(Object var1, long var2, long var4, long var6);

抵消:對象在內(nèi)存中包含對象頭和對象實例數(shù)據(jù),和對象頭占8個字節(jié)。對于64位的操作系統(tǒng),壓縮指針占4個字節(jié),所以我們通常說的對象頭占12個字節(jié);例如,測試對象,x的偏置是頭的對象,也就是說,12個字節(jié),和y的抵消是16

cas操作修改測試類的變量x。

public class CASTest {    public static void main(String[] args) {
        Test test = new Test();
        Unsafe unsafe = UnsafeFactory.getUnsafe();        long xOffset = UnsafeFactory.getFieldOffset(unsafe, Test.class, "x");
        System.out.println(xOffset); //12
        long yOffset = UnsafeFactory.getFieldOffset(unsafe, Test.class, "y");
        System.out.println(yOffset); //16
        unsafe.compareAndSwapInt(test, xOffset, 0, 1);
        System.out.println(test.x);
    }    
    static class Test {        int x;        int y;
    }
}

能保證原子性,但不能保證秩序和可見性。因此,一般來說,可以用于揮發(fā)性,以確保線程安全。底層最后執(zhí)行CAS指令(原子操作修改變量值)和比較期望值與實際值在內(nèi)存中。如果比較結(jié)果相等,返回舊值(期望值),表明CAS操作成功。如果他們是不平等的,在內(nèi)存返回實際值,表明CAS操作失敗。

CAS實現(xiàn)線程安全的操作

public class CASTest {    private static int sum = 0;    private static CASLock casLock = new CASLock();    public static void main(String[] args) throws InterruptedException {        for (int i=0; i<10; i++) {            new Thread(() -> {                for (;;) {                    if (casLock.getState() == 0 && casLock.cas()) {                        try {                            for (int j = 0; j < 10000; j++) {
                                sum++;
                            }
                        } finally {
                            casLock.setState(0);
                        }                        break;
                    }
                }
            }).start();
        }
        Thread.sleep(2000);
        System.out.println(sum);
    }
}
public class CASLock {    private volatile int state = 0;    private static final Unsafe UNSAFE;    private static final long OFFSET;    static {
        UNSAFE = UnsafeFactory.getUnsafe();
        OFFSET = UnsafeFactory.getFieldOffset(UNSAFE, CASLock.class, "state");
    }    
    public int getState() {        return state;
    }    public void setState(int state) {        this.state = state;
    }    public boolean cas() {        return UNSAFE.compareAndSwapInt(this, OFFSET, 0, 1);
    }
}

原子在jdk類juc下包通過cas是線程安全的。

LongAdder和DoubleAdder原則

在高并發(fā)性下,CAS操作將有大量的線程旋轉(zhuǎn),導致浪費線程資源。為了提高執(zhí)行效率,V值分為多個變量。多個線程執(zhí)行CAS操作同時在自己的變量。所有線程完成后執(zhí)行,所有變量都是積累和統(tǒng)計。它的想法是類似于統(tǒng)計jdk8 ConcurrentHashMap的元素的數(shù)量。LongAdder DoubleAdder也實現(xiàn)這個想法。LongAdder定義了基本變量和單元數(shù)組變量,初始化并積累單元陣列通過散列,最后積累基礎(chǔ)和單元陣列的所有數(shù)字的結(jié)果。

“Java中cas實現(xiàn)原理是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

分享文章:Java中cas實現(xiàn)原理是什么
當前網(wǎng)址:http://www.rwnh.cn/article0/ghcpoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、定制網(wǎng)站、搜索引擎優(yōu)化、做網(wǎng)站、響應(yīng)式網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
封丘县| 鸡西市| 伊通| 曲松县| 宁远县| 赤壁市| 郧西县| 肥西县| 塔城市| 青冈县| 库尔勒市| 凤台县| 新沂市| 垣曲县| 涟水县| 清新县| 施秉县| 清徐县| 措勤县| 哈巴河县| 温宿县| 黄大仙区| 巴青县| 东至县| 吉水县| 普定县| 大足县| 广德县| 同德县| 韶关市| 临泽县| 浦城县| 高州市| 柘荣县| 化德县| 竹溪县| 大渡口区| 屏南县| 沿河| 龙井市| 平和县|