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

溫馨提示×

溫馨提示×

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

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

詳解Java利用ExecutorService實現同步執行大量線程

發布時間:2020-08-22 19:34:47 來源:腳本之家 閱讀:326 作者:關瑋琳linSir 欄目:編程語言

自從java1.5以后,官網就推出了Executor這樣一個類,這個類,可以維護我們的大量線程在操作臨界資源時的穩定性。
先上一段代碼吧:

TestRunnable.java

public class TestRunnable implements Runnable {
  private String name;

  public TestRunnable(String name) {
    this.name = name;
  }

  @Override
  public void run() {
    while (true) {
      if (Main.Surplus < 0)
        return;
      Main.Surplus--;
      System.out.println(name + " " + Main.Surplus);
    }
  }
}

main入口

public static void main(String[] args) {

     TestRunnable runnable = new TestRunnable("runnable1");
     TestRunnable runnable2 = new TestRunnable("runnable2");

     Thread t1 = new Thread(runnable);
     Thread t2 = new Thread(runnable2);

     t1.start();
     t2.start();

  }

詳解Java利用ExecutorService實現同步執行大量線程

這樣,我們就看到了,數據肯定是亂了的,當然這個時候我們可以加上一個synchronized的關鍵字,但是這樣也會出現點小問題的

詳解Java利用ExecutorService實現同步執行大量線程

下面我打算采用一種java內置的線程管理的機制,來解決這個問題,解決這個問題的思路大概就是,我們維護了一個線程池,當有請求操作的時候統統進入線程池,并且我們只開了一個線程,可以讓請求順序執行,順序調用臨界資源,就很安全了。

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class Main {
  public static int Surplus = 10;

  private ExecutorService executor = Executors.newSingleThreadExecutor();

  void addTask(Runnable runnable) {
    executor.execute(runnable);
  }

  <V> V addTask(Callable<V> callable) {
    Future<V> submit = executor.submit(callable);
    try {
      return submit.get();
    } catch (InterruptedException e) {
      System.out.println("InterruptedException" + e.toString());
    } catch (ExecutionException e) {
      System.out.println("ExecutionException" + e.toString());
    }
    return null;
  }

  public void testAddTask(String name) {
    addTask(new Runnable() {
      @Override
      public void run() {
        for (int i = 0; i < 3; i++) {
          if (Main.Surplus <= 0)
            return;
          Main.Surplus--;
          System.out.println(name + " " + Main.Surplus);
        }

      }
    });
  }

  public void testAddTask2(String name) {
    int count = addTask(new Callable<Integer>() {
      @Override
      public Integer call() throws Exception {
        for (int i = 0; i < 3; i++) {
          if (Main.Surplus <= 0)
            return 0;
          Main.Surplus--;
          System.out.println(name + " " + Main.Surplus);
        }
        return Main.Surplus;
      }
    });

  }

  public void close() {
    executor.shutdown();
  }

  public static void main(String[] args) {
    Main main = new Main();
    main.testAddTask("task1");
    main.testAddTask2("task2");
    main.testAddTask("task3");
    main.testAddTask2("task4");
    main.close();
  }
}

在這里,我們定義了兩種方法,分別是addTask,具有泛型的addTask,這兩種方法實現原理都是一樣的,其中一個是有回調的,一個是沒有回調的,就看項目需求了吧。

詳解Java利用ExecutorService實現同步執行大量線程

然后分別調用這兩個方法咯,就可以看到結果是非常有序,且不會混亂的。

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

向AI問一下細節

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

AI

新建县| 泸水县| 九江县| 乌恰县| 桐城市| 青铜峡市| 吉木乃县| 杂多县| 观塘区| 屏山县| 永定县| 平顺县| 湄潭县| 泉州市| 城固县| 奉化市| 息烽县| 德惠市| 连平县| 布尔津县| 屏南县| 安岳县| 乐亭县| 章丘市| 庆城县| 昔阳县| 时尚| 沈阳市| 梁山县| 微山县| 峡江县| 正阳县| 沁阳市| 三门县| 营口市| 阿合奇县| 湘西| 惠州市| 西藏| 普定县| 广灵县|