溫馨提示×

溫馨提示×

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

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

怎么在Java中利用LockSupport類實現并發編程

發布時間:2021-05-17 15:22:29 來源:億速云 閱讀:172 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關怎么在Java中利用LockSupport類實現并發編程,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

一、LockSupport類的屬性

怎么在Java中利用LockSupport類實現并發編程

private static final sun.misc.Unsafe UNSAFE;
    // 表示內存偏移地址
    private static final long parkBlockerOffset;
    // 表示內存偏移地址
    private static final long SEED;
    // 表示內存偏移地址
    private static final long PROBE;
    // 表示內存偏移地址
    private static final long SECONDARY;
    static {
        try {
            // 獲取Unsafe實例
            UNSAFE = sun.misc.Unsafe.getUnsafe();
            // 線程類類型
            Class<?> tk = Thread.class;
            // 獲取Thread的parkBlocker字段的內存偏移地址
            parkBlockerOffset = UNSAFE.objectFieldOffset(tk.getDeclaredField("parkBlocker"));
            // 獲取Thread的threadLocalRandomSeed字段的內存偏移地址
            SEED = UNSAFE.objectFieldOffset(tk.getDeclaredField("threadLocalRandomSeed"));
            // 獲取Thread的threadLocalRandomProbe字段的內存偏移地址
            PROBE = UNSAFE.objectFieldOffset(tk.getDeclaredField("threadLocalRandomProbe"));
            // 獲取Thread的threadLocalRandomSecondarySeed字段的內存偏移地址
            SECONDARY = UNSAFE.objectFieldOffset(tk.getDeclaredField("threadLocalRandomSecondarySeed"));
        } catch (Exception ex) { throw new Error(ex); }
    }

二、LockSupport類的構造函數

怎么在Java中利用LockSupport類實現并發編程

 // 私有構造函數,無法被實例化
    private LockSupport() {

    }

三、park(Object blocker)方法 和 park()方法分析

怎么在Java中利用LockSupport類實現并發編程

//調用park函數時,當前線程首先設置好parkBlocker字段,然后再調用 Unsafe的park函數
    // 此后,當前線程就已經阻塞了,等待該線程的unpark函數被調用,所以后面的一個 setBlocker函數無法運行
    // unpark函數被調用,該線程獲得許可后,就可以繼續運行了,也就運行第二個 setBlocker
    // 把該線程的parkBlocker字段設置為null,這樣就完成了整個park函數的邏輯。
    // 總之,必須要保證在park(Object blocker)整個函數 執行完后,該線程的parkBlocker字段又恢復為null。

    //阻塞當前線程,并且將當前線程的parkBlocker字段設置為blocker
    public static void park(Object blocker) {
        // 獲取當前線程
        Thread t = Thread.currentThread();
        //將當前線程的parkBlocker字段設置為blocker
        setBlocker(t, blocker);
        //阻塞當前線程,第一個參數表示isAbsolute,是否為絕對時間,第二個參數就是代表時間
        UNSAFE.park(false, 0L);
        //重新可運行后再此設置Blocker
        setBlocker(t, null);
    }

    //無限阻塞線程,直到有其他線程調用unpark方法
    public static void park() {
        UNSAFE.park(false, 0L);
    }

四、parkNanos(Object blocker,long nanos)方法 和 parkNanos(long nanos)方法分析

怎么在Java中利用LockSupport類實現并發編程

//阻塞當前線程nanos秒 毫秒
    public static void parkNanos(Object blocker, long nanos) {
        //先判斷nanos是否大于0,小于等于0都代表無限等待
        if (nanos > 0) {
            // 獲取當前線程
            Thread t = Thread.currentThread();
            //將當前線程的parkBlocker字段設置為blocker
            setBlocker(t, blocker);
            //阻塞當前線程現對時間的nanos秒
            UNSAFE.park(false, nanos);
            //將當前線程的parkBlocker字段設置為null
            setBlocker(t, null);
        }
    }

    //阻塞當前線程nanos秒 毫秒
    public static void parkNanos(long nanos) {
        if (nanos > 0)
            UNSAFE.park(false, nanos);
    }

五、parkUntil(Object blocker,long deadline)方法 和 parkUntil(long deadline)方法分析

怎么在Java中利用LockSupport類實現并發編程

//將當前線程阻塞絕對時間的deadline秒,并且將當前線程的parkBlockerOffset設置為blocker
    public static void parkUntil(Object blocker, long deadline) {
        //獲取當前線程
        Thread t = Thread.currentThread();
        //設置當前線程parkBlocker字段設置為blocker
        setBlocker(t, blocker);
        //阻塞當前線程絕對時間的deadline秒
        UNSAFE.park(true, deadline);
        //當前線程parkBlocker字段設置為null
        setBlocker(t, null);
    }

    //將當前線程阻塞絕對時間的deadline秒
    public static void parkUntil(long deadline) {
        UNSAFE.park(true, deadline);
    }

六、setBlocker(Thread t, Object arg)和 getBlocker(Thread t) 方法分析

怎么在Java中利用LockSupport類實現并發編程

// 設置線程t的parkBlocker字段的值為arg
    private static void setBlocker(Thread t, Object arg) {
        UNSAFE.putObject(t, parkBlockerOffset, arg);
    }


    //獲取當前線程的Blocker值
    public static Object getBlocker(Thread t) {
        //若當前線程為空就拋出異常
        if (t == null)
            throw new NullPointerException();
        //利用unsafe對象獲取當前線程的Blocker值
        return UNSAFE.getObjectVolatile(t, parkBlockerOffset);
    }

七、unpark(Thread thread) 方法分析

怎么在Java中利用LockSupport類實現并發編程

 //釋放該線程的阻塞狀態,即類似釋放鎖,只不過這里是將許可設置為1
    public static void unpark(Thread thread) {
        // 線程為不空
        if (thread != null)
            // 釋放該線程許可
            UNSAFE.unpark(thread);
    }

八、LockSupport優點

LockSupport比Object的wait/notify有兩大優勢

1.LockSupport不需要在同步代碼塊里 。所以線程間也不需要維護一個共享的同步對象了,實現了線程間的解耦。

2.unpark函數可以先于park調用,所以不需要擔心線程間的執行的先后順序。

Java可以用來干什么

Java主要應用于:1. web開發;2. Android開發;3. 客戶端開發;4. 網頁開發;5. 企業級應用開發;6. Java大數據開發;7.游戲開發等。

看完上述內容,你們對怎么在Java中利用LockSupport類實現并發編程有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女