91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

深入淺析Java 中的LockSupport

發布時間:2020-11-23 17:15:48 來源:億速云 閱讀:141 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關深入淺析Java 中的LockSupport,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

LockSupport介紹

LockSupport是用來創建鎖和其他同步類的基本線程阻塞原語。
LockSupport中的park() 和 unpark() 的作用分別是阻塞線程和解除阻塞線程,而且park()和unpark()不會遇到“Thread.suspend 和 Thread.resume所可能引發的死鎖”問題。
因為park() 和 unpark()有許可的存在;調用 park() 的線程和另一個試圖將其 unpark() 的線程之間的競爭將保持活性。

LockSupport函數列表

// 返回提供給最近一次尚未解除阻塞的 park 方法調用的 blocker 對象,如果該調用不受阻塞,則返回 null。
static Object getBlocker(Thread t)
// 為了線程調度,禁用當前線程,除非許可可用。
static void park()
// 為了線程調度,在許可可用之前禁用當前線程。
static void park(Object blocker)
// 為了線程調度禁用當前線程,最多等待指定的等待時間,除非許可可用。
static void parkNanos(long nanos)
// 為了線程調度,在許可可用前禁用當前線程,并最多等待指定的等待時間。
static void parkNanos(Object blocker, long nanos)
// 為了線程調度,在指定的時限前禁用當前線程,除非許可可用。
static void parkUntil(long deadline)
// 為了線程調度,在指定的時限前禁用當前線程,除非許可可用。
static void parkUntil(Object blocker, long deadline)
// 如果給定線程的許可尚不可用,則使其可用。
static void unpark(Thread thread)

LockSupport示例

對比下面的“示例1”和“示例2”可以更清晰的了解LockSupport的用法。

示例1

public class WaitTest1 {

  public static void main(String[] args) {

    ThreadA ta = new ThreadA("ta");

    synchronized(ta) { // 通過synchronized(ta)獲取“對象ta的同步鎖”
      try {
        System.out.println(Thread.currentThread().getName()+" start ta");
        ta.start();

        System.out.println(Thread.currentThread().getName()+" block");
        // 主線程等待
        ta.wait();

        System.out.println(Thread.currentThread().getName()+" continue");
      } catch (InterruptedException e) {
        e.printStackTrace();
      }
    }
  }

  static class ThreadA extends Thread{

    public ThreadA(String name) {
      super(name);
    }

    public void run() {
      synchronized (this) { // 通過synchronized(this)獲取“當前對象的同步鎖”
        System.out.println(Thread.currentThread().getName()+" wakup others");
        notify();  // 喚醒“當前對象上的等待線程”
      }
    }
  }
}

示例2

import java.util.concurrent.locks.LockSupport;

public class LockSupportTest1 {

  private static Thread mainThread;

  public static void main(String[] args) {

    ThreadA ta = new ThreadA("ta");
    // 獲取主線程
    mainThread = Thread.currentThread();

    System.out.println(Thread.currentThread().getName()+" start ta");
    ta.start();

    System.out.println(Thread.currentThread().getName()+" block");
    // 主線程阻塞
    LockSupport.park(mainThread);

    System.out.println(Thread.currentThread().getName()+" continue");
  }

  static class ThreadA extends Thread{

    public ThreadA(String name) {
      super(name);
    }

    public void run() {
      System.out.println(Thread.currentThread().getName()+" wakup others");
      // 喚醒“主線程”
      LockSupport.unpark(mainThread);
    }
  }
}

運行結果:

main start ta
main block
ta wakup others
main continue

說明:park和wait的區別。wait讓線程阻塞前,必須通過synchronized獲取同步鎖。

上述就是小編為大家分享的深入淺析Java 中的LockSupport了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

贵定县| 道孚县| 万山特区| 阿瓦提县| 平定县| 尼勒克县| 体育| 保德县| 松原市| 清苑县| 罗平县| 大余县| 凤山市| 辽宁省| 会东县| 霍城县| 崇礼县| 呼伦贝尔市| 乌海市| 无棣县| 新乡市| 沅江市| 枞阳县| 邵阳市| 始兴县| 石狮市| 包头市| 尉犁县| 安化县| 延庆县| 贵州省| 长治市| 平利县| 嵩明县| 土默特左旗| 邢台县| 邓州市| 科技| 肇庆市| 桓仁| 宁夏|