中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

ExecutorService 于 Executors 在java中的區別有哪些

發布時間:2020-11-23 16:24:50 來源:億速云 閱讀:208 作者:Leah 欄目:編程語言

今天就跟大家聊聊有關ExecutorService 于 Executors 在java中的區別有哪些,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

java 中Executor, ExecutorService 和 Executors 間的不同

java.util.concurrent.Executor, java.util.concurrent.ExecutorService, java.util.concurrent. Executors 這三者均是 Java Executor 框架的一部分,用來提供線程池的功能。因為創建和管理線程非常心累,并且操作系統通常對線程數有限制,所以建議使用線程池來并發執行任務,而不是每次請求進來時創建一個線程。使用線程池不僅可以提高應用的響應時間,還可以避免”java.lang.OutOfMemoryError: unable to create new native thread” 之類的錯誤。

在 Java 1.5 時,開發者需要關心線程池的創建和管理,但在 Java 1.5 之后 Executor 框架提供了多種內置的線程池,例如:FixedThreadPool(包含固定數目的線程),CachedThreadPool(可根據需要創建新的線程)等等。

Executor

Executor, ExecutorService, 和 Executors 最主要的區別是 Executor 是一個抽象層面的核心接口(大致代碼如下)。

public interface Executor {
 void execute(Runnable command);
}

不同于 java.lang.Thread 類將任務和執行耦合在一起, Executor 將任務本身和執行任務分離,可以閱讀 difference between Thread and Executor 來了解 Thread 和 Executor 間更多的不同。

ExecutorService

ExecutorService 接口 對 Executor 接口進行了擴展,提供了返回 Future 對象,終止,關閉線程池等方法。當調用 shutDown 方法時,線程池會停止接受新的任務,但會完成正在 pending 中的任務。

Future 對象提供了異步執行,這意味著無需等待任務執行的完成,只要提交需要執行的任務,然后在需要時檢查 Future 是否已經有了結果,如果任務已經執行完成,就可以通過 Future.get() 方法獲得執行結果。需要注意的是,Future.get() 方法是一個阻塞式的方法,如果調用時任務還沒有完成,會等待直到任務執行結束。

通過 ExecutorService.submit() 方法返回的 Future 對象,還可以取消任務的執行。Future 提供了 cancel() 方法用來取消執行 pending 中的任務。

ExecutorService 部分代碼如下:

public interface ExecutorService extends Executor {
 void shutdown();
 <T> Future<T> submit(Callable<T> task);
 <T> Future<T> submit(Runnable task, T result);
 <T> List<Future<T>> invokeAll(Collection<&#63; extends Callable<T>> tasks, long timeout, TimeUnit unit) throws InterruptedException;
}

Executors

Executors 是一個工具類,類似于 Collections。提供工廠方法來創建不同類型的線程池,比如 FixedThreadPool 或 CachedThreadPool。

Executors 部分代碼:

public class Executors {
 public static ExecutorService newFixedThreadPool(int nThreads) {
  return new ThreadPoolExecutor(nThreads, nThreads, 0L, TimeUnit.MILLISECONDS,new LinkedBlockingQueue<Runnable>());
  }
   
  public static ExecutorService newCachedThreadPool() {
  return new ThreadPoolExecutor(0, Integer.MAX_VALUE, 60L, TimeUnit.SECONDS, new SynchronousQueue<Runnable>());
  }
}

下面詳細看一下三者的區別:

Executor vs ExecutorService vs Executors

正如上面所說,這三者均是 Executor 框架中的一部分。Java 開發者很有必要學習和理解他們,以便更高效的使用 Java 提供的不同類型的線程池。總結一下這三者間的區別,以便大家更好的理解:

·         Executor 和 ExecutorService 這兩個接口主要的區別是:ExecutorService 接口繼承了 Executor 接口,是 Executor 的子接口

·         Executor 和 ExecutorService 第二個區別是:Executor 接口定義了 execute()方法用來接收一個Runnable接口的對象,而 ExecutorService 接口中的 submit()方法可以接受Runnable和Callable接口的對象。

·         Executor 和 ExecutorService 接口第三個區別是 Executor 中的 execute() 方法不返回任何結果,而 ExecutorService 中的 submit()方法可以通過一個 Future 對象返回運算結果。

·         Executor 和 ExecutorService 接口第四個區別是除了允許客戶端提交一個任務,ExecutorService 還提供用來控制線程池的方法。比如:調用 shutDown() 方法終止線程池。可以通過 《Java Concurrency in Practice》 一書了解更多關于關閉線程池和如何處理 pending 的任務的知識。

·         Executors 類提供工廠方法用來創建不同類型的線程池。比如: newSingleThreadExecutor() 創建一個只有一個線程的線程池,newFixedThreadPool(int numOfThreads)來創建固定線程數的線程池,newCachedThreadPool()可以根據需要創建新的線程,但如果已有線程是空閑的會重用已有線程。

總結

下表列出了 Executor 和 ExecutorService 的區別:

ExecutorService 于 Executors 在java中的區別有哪些

看完上述內容,你們對ExecutorService 于 Executors 在java中的區別有哪些有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

AI

赣榆县| 五峰| 洞头县| 永昌县| 田东县| 莱州市| 开原市| 庆城县| 高密市| 任丘市| 新泰市| 革吉县| 沂水县| 丹巴县| 大兴区| 信丰县| 怀远县| 宾阳县| 井研县| 乌鲁木齐县| 巩义市| 林周县| 务川| 景谷| 深圳市| 合川市| 平和县| 正镶白旗| 大连市| 尼勒克县| 平陆县| 化隆| 巴中市| 百色市| 天峻县| 明光市| 信宜市| 大新县| 壶关县| 鹤庆县| 武清区|