亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java中cas實現原理是什么

發布時間:2022-09-30 17:03:08 來源:億速云 閱讀:111 作者:iii 欄目:編程語言

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

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);

抵消:對象在內存中包含對象頭和對象實例數據,和對象頭占8個字節。對于64位的操作系統,壓縮指針占4個字節,所以我們通常說的對象頭占12個字節;例如,測試對象,x的偏置是頭的對象,也就是說,12個字節,和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;
    }
}

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

CAS實現線程安全的操作

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原則

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

“Java中cas實現原理是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

临清市| 溆浦县| 喜德县| 广水市| 盐山县| 奉贤区| 温宿县| 容城县| 曲水县| 揭东县| 哈尔滨市| 休宁县| 宁晋县| 永寿县| 宜宾市| 普兰店市| 法库县| 平山县| 淳安县| 乃东县| 阿勒泰市| 钟祥市| 册亨县| 梁河县| 策勒县| 天柱县| 云阳县| 临澧县| 淄博市| 沁水县| 观塘区| 甘泉县| 沂南县| 武义县| 富平县| 双峰县| 勃利县| 乌兰察布市| 黎城县| 仙桃市| 庆城县|