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

溫馨提示×

溫馨提示×

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

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

Java多線程怎么實現按指定順序同步執行

發布時間:2021-06-15 15:08:54 來源:億速云 閱讀:399 作者:Leah 欄目:編程語言

今天就跟大家聊聊有關Java多線程怎么實現按指定順序同步執行,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

方法1 使用newSingleThreadExecutor

newSingleThreadExecutor返回僅僅包含一個線程的線程池,將多個任務交給此Executor時,這個線程池處理完一個任務后接著處理下一個任務,這樣就保證了執行順序,先提交先執行。如果當前線程意外終止,會創建一個新線程繼續執行任務。

示例代碼如下:

ExecutorService pool = Executors.newSingleThreadExecutor();
    for(int i=0;i<1000;++i) {
      final int number = i;
      pool.execute(()-> {
        System.out.println("I am " + number);
      } );
    }
pool.shutdown();

方法2 使用join方法

When we call this method using a thread object, it suspends the execution of the calling thread until the object called finishes its execution.

英語原版其實很拗口,不好理解。簡單點說,就是某個線程A調用join,其他線程就要乖乖等A執行完畢才能執行。

示例代碼如下:

public class Worker implements Runnable {

  private int number;
  public Worker(int i) {
    number = i;
  }
  
  @Override
  public synchronized void run() {
    System.out.println("I am " + number);
  }
}
public class TestWorker {

  public static void main(String[] args) {
    
    for(int j=0;j<1000;++j) {
      Thread thread = new Thread(new Worker(j));
      thread.start();
      try {
        thread.join();
      } catch (InterruptedException e) {
        e.printStackTrace();
      }
    }
  }
}

方法3 使用ThreadPoolExecutor,設置它的核心線程數為1

我們先分析一下ThreadPoolExecutor,其構造函數如下

public ThreadPoolExecutor(int corePoolSize,
               int maximumPoolSize,
               long keepAliveTime,
               TimeUnit unit,
               BlockingQueue<Runnable> workQueue,
               ThreadFactory threadFactory,               
               RejectedExecutionHandler handler)

各個參數含義如下:

1、corePoolSize, 核心線程數,建議和cpu的核心數一樣,當有任務提交,檢測當前線程池內的線程數小于corePoolSize的話,新建線程執行任務,直到達到corePoolSize。線程池內的線程數大于等于corePoolSize時,將任務放入workQueue等待。

2、maximumPoolSize,允許線程池內最大線程數,當隊列滿了之后,如果線程池內的線程數小于maximumPoolSize新建線程,如果大于等于執行拒絕策略。

3、keepAliveTime,線程最大空閑時間,如果設置60s,那么線程空閑60s后自動結束。

unit,時間單位分鐘,秒等等。

4、workQueue,線程數超過corePoolSize存放任務的地方。

5、threadFactory,線程工廠,默認的即可。

6、handler,拒絕策略,分4種,AbortPolicy直接拋出異常、DiscardPolicy悄悄拋棄不執行、CallerRunsPolicy(調用者運行):該策略既不會拋棄任務也不會拋出異常,而是將這個任務退回給調用者,從而降低新任務的流量;、DiscardOldestPolicy(拋棄最舊的)

示例代碼如下:

ExecutorService pool = new ThreadPoolExecutor(1, 1000, 300, TimeUnit.SECONDS, 
        new LinkedBlockingQueue<Runnable>(1000),Executors.defaultThreadFactory(), 
        new ThreadPoolExecutor.AbortPolicy());
    for(int i=0;i<1000;++i) {
      final int number = i;
      pool.execute(()-> {
        System.out.println("I am " + number);
      } );
    }
pool.shutdown();

4. 執行結果

I am 0
I am 1
I am 2
I am 3
I am 4
I am 5
I am 6
I am 7
I am 8
I am 9
I am 10

。。。

I am 990
I am 991
I am 992
I am 993
I am 994
I am 995
I am 996
I am 997
I am 998
I am 999

看完上述內容,你們對Java多線程怎么實現按指定順序同步執行有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

AI

陆川县| 德钦县| 龙州县| 枞阳县| 迁西县| 怀安县| 阿拉尔市| 龙南县| 休宁县| 松原市| 黔西县| 彝良县| 黔西| 西畴县| 上饶县| 新乐市| 新闻| 子洲县| 云阳县| 元江| 青浦区| 抚宁县| 镇平县| 阳谷县| 叙永县| 西畴县| 紫云| 清原| 化隆| 巴中市| 乌鲁木齐市| 镇沅| 察隅县| 轮台县| 桦南县| 望奎县| 榆树市| 临漳县| 巴南区| 老河口市| 上饶县|