国产色诱美女免费视频|欧美精彩狠狠色丁香婷婷|91黑人|日本黄色小视频|欧美一级黄色视频在这里免费观看

IT培訓(xùn)-高端面授IT培訓(xùn)機(jī)構(gòu)
云和教育:云和數(shù)據(jù)集團(tuán)高端IT職業(yè)教育品牌
  • 國家級
    全民數(shù)字素養(yǎng)與技能培訓(xùn)基地
  • 河南省
    第一批產(chǎn)教融合型企業(yè)建設(shè)培育單位
  • 鄭州市
    數(shù)字技能人才(碼農(nóng))培養(yǎng)評價(jià)聯(lián)盟

AQS框架了解過嗎?具體是干嘛的?

  • 發(fā)布時(shí)間:
    2023-04-12
  • 版權(quán)所有:
    云和教育
  • 分享:

AQS(AbstractQueuedSynchronizer)是Java中用于構(gòu)建同步器的框架,它提供了一種實(shí)現(xiàn)各種同步器的通用框架,例如ReentrantLock、Semaphore、CountDownLatch等等。

AQS框架的核心思想是使用一個(gè)雙向鏈表來維護(hù)等待線程隊(duì)列,同時(shí)使用一個(gè)狀態(tài)變量來表示當(dāng)前同步器的狀態(tài)。當(dāng)線程請求獲取同步器的鎖時(shí),如果同步器已經(jīng)被占用,那么線程就會被加入等待隊(duì)列中,并阻塞自己,等待被喚醒;如果同步器未被占用,則線程直接獲取同步器的鎖,并將同步器的狀態(tài)設(shè)置為“已占用”。

 

下面是一個(gè)簡單的示例,演示了如何使用 AQS 框架來實(shí)現(xiàn)一個(gè)簡單的計(jì)數(shù)器:

import java.util.concurrent.locks.AbstractQueuedSynchronizer;

public class Counter {
    private final Sync sync = new Sync();

    public void increment() {
        sync.acquire(1);
        try {
            // 進(jìn)行計(jì)數(shù)器加一操作
        } finally {
            sync.release(1);
        }
    }

    public int getCount() {
        return sync.getCount();
    }

    private static class Sync extends AbstractQueuedSynchronizer {
        private static final long serialVersionUID = 1L;

        protected boolean tryAcquire(int arg) {
            return compareAndSetState(0, arg);
        }

        protected boolean tryRelease(int arg) {
            int c = getState() - arg;
            if (c == 0) {
                return true;
            }
            if (c < 0) {
                throw new IllegalStateException("Counter underflow");
            }
            setState(c);
            return false;
        }

        public int getCount() {
            return getState();
        }
    }
}

在上面的示例中,Counter類包含一個(gè)Sync類的實(shí)例,它繼承了AbstractQueuedSynchronizer并實(shí)現(xiàn)了 tryAcquire()、tryRelease()方法。increment()方法首先嘗試獲取同步器的鎖(即調(diào)用 acquire() 方法),然后進(jìn)行計(jì)數(shù)器加一操作,最后釋放同步器的鎖(即調(diào)用release() 方法)。getCount()方法返回當(dāng)前計(jì)數(shù)器的值,即同步器的狀態(tài)。