一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java concurrency之LockSupport_動力節點Java學院整理

Java concurrency之LockSupport_動力節點Java學院整理

2020-11-15 20:06skywang12345 Java教程

這篇文章主要為大家詳細介紹了Java concurrency之LockSupport的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

LockSupport介紹

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

LockSupport函數列表

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// 返回提供給最近一次尚未解除阻塞的 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

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
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獲取同步鎖。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲国产日韩欧美在线vip1区 | aaa一级毛片免费 | 国产麻豆精品入口在线观看 | 免费看的毛片 | 欧美milk大超乳| 桃色视频破解版 | 操娇妻 | 男生操男生 | 精品国产91久久久久久久a | 亚洲香蕉综合在人在线视看 | 99热线| xnxx动漫| 国产福利一区二区三区 | 日本妇人成熟免费不卡片 | 欧美日韩精 | 艾秋麻豆果冻传媒老狼仙踪林 | 国产精品免费_区二区三区观看 | 国产91在线精品 | 美女任你摸 | 亚洲mv国产精品mv日本mv | 精品亚洲午夜久久久久 | 日本黄大片影院一区二区 | 香蕉久久网| 亚洲精品视频在线 | 国产亚洲精品一区二区在线播放 | 91久久综合九色综合欧美98 | www黄| 教室里老师好紧h | 日本欧美强乱视频在线 | 青青草视频国产 | 天天欲色成人综合网站 | 日本小视频免费 | 国产免费午夜 | 高级黄色片 | 亚洲成在人线视频 | 亚洲午夜精品久久久久久成年 | 啪啪免费网址 | 免费国产影视观看网站入口 | 色婷丁香 | 猛h辣h高h文湿校园1v1 | jizzjizz3d动漫 |