亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺談在Java中使用Callable、Future進(jìn)行并行編程

 更新時(shí)間:2017年12月06日 08:43:04   作者:老鷹  
這篇文章主要介紹了淺談在Java中使用Callable、Future進(jìn)行并行編程,具有一定借鑒價(jià)值,需要的朋友可以參考下。

使用Callable、Future進(jìn)行并行編程

在Java中進(jìn)行并行編程最常用的方式是繼承Thread類或者實(shí)現(xiàn)Runnable接口。這兩種方式的缺點(diǎn)是在任務(wù)完成后無(wú)法直接獲取執(zhí)行結(jié)果,必須通過(guò)共享變量或線程間通信,使用起來(lái)很不方便。

從Java1.5開(kāi)始提供了Callable和Future兩個(gè)接口,通過(guò)使用它們可以在任務(wù)執(zhí)行完畢后得到執(zhí)行結(jié)果。

下面我們來(lái)學(xué)習(xí)下如何使用Callable、Future和FutureTask。

Callable接口

Callable接口位于java.util.concurrent包,這是一個(gè)泛型接口,里面只聲明了一個(gè)call()方法:

public interface Callable<T> {
  T call() throws Exception;
}

一般配合ExecutorService接口來(lái)使用它,在ExecutorService接口中聲明了幾個(gè)重載的submit方法:

<T> Future<T> submit(Callable<T> task);
<T> Future<T> submit(Runnable task, T result);
Future<?> submit(Runnable task);

第一個(gè)submit方法里面的參數(shù)類型就是Callable,另外兩個(gè)本文暫時(shí)不涉及。

Future和FutureTask

Future接口的實(shí)現(xiàn)類可以對(duì)Runnable或者Callable的任務(wù)執(zhí)行取消、查詢、獲取結(jié)果的操作。

Future接口也位于java.util.concurrent包下:

public interface Future<T> {
  /**
  *取消任務(wù)
  *@param mayInterruptIfRunning
  *是否允許取消正在執(zhí)行卻沒(méi)有執(zhí)行完畢的任務(wù),如果設(shè)置true,則表示可以取消正在執(zhí)行過(guò)程中的任務(wù)
  *如果任務(wù)正在執(zhí)行,則返回true
  *如果任務(wù)還沒(méi)有執(zhí)行,則無(wú)論mayInterruptIfRunning為true還是false,返回true
  *如果任務(wù)已經(jīng)完成,則無(wú)論mayInterruptIfRunning為true還是false,返回false
  */
  boolean cancel(boolean mayInterruptIfRunning);
  /**
  *任務(wù)是否被取消成功,如果在任務(wù)正常完成前被取消成功,則返回 true
  */
  boolean isCancelled();
  /**
  *任務(wù)是否完成
  */
  boolean isDone();
  /**
  *通過(guò)阻塞獲取執(zhí)行結(jié)果
  */
  T get() throws InterruptedException, ExecutionException;
  /**
  *通過(guò)阻塞獲取執(zhí)行結(jié)果。如果在指定的時(shí)間內(nèi)沒(méi)有返回,則返回null
  */
  T get(long timeout, TimeUnit unit)
    throws InterruptedException, ExecutionException, TimeoutException;
}

總結(jié)下來(lái)Future提供了三種功能:

判斷任務(wù)是否完成
能夠中斷任務(wù)
能夠獲取任務(wù)執(zhí)行的結(jié)果

JDK中為我們提供了一個(gè)Future接口的實(shí)現(xiàn)類FutureTask,它有如下兩個(gè)構(gòu)造函數(shù)。

public FutureTask(Callable<T> callable) {
}
public FutureTask(Runnable runnable, T result) {
}

示例代碼

使用Callable、Future

import java.util.concurrent.*;
public class Test {
  public static void main(String[] args) {
    ExecutorService executorService = Executors.newCachedThreadPool();
    Task task = new Task();
    Future<Integer> future = executorService.submit(task);
    executorService.shutdown();
    
    System.out.println("主線程在執(zhí)行任務(wù)...");
    try {
      Thread.sleep(2000);
    } catch(InterruptedException ex) {
      ex.printStackTrace();
    }
     
    try {
      System.out.println("task運(yùn)行結(jié)果:"+future.get());
    } catch (InterruptedException ex) {
      ex.printStackTrace();
    } catch (ExecutionException ex) {
      ex.printStackTrace();
    } 
    System.out.println("所有任務(wù)執(zhí)行完畢");
  }
}
class Task implements Callable<Integer>{
  @Override
  public Integer call() throws Exception {
    System.out.println("子線程在執(zhí)行任務(wù)...");
    //模擬任務(wù)耗時(shí)
    Thread.sleep(5000);
    return 1000;
  }
}

執(zhí)行結(jié)果:

子線程在執(zhí)行任務(wù)...
主線程在執(zhí)行任務(wù)...
task運(yùn)行結(jié)果:1000
所有任務(wù)執(zhí)行完畢

使用Callable、FutureTask

import java.util.concurrent.*;
public class Test {
  public static void main(String[] args) {
    ExecutorService executorService = Executors.newCachedThreadPool();
    Task task = new Task();
    FutureTask<Integer> futureTask = new FutureTask<Integer>(task);
    executorService.submit(futureTask);
    executorService.shutdown();
    
    System.out.println("主線程在執(zhí)行任務(wù)...");
    try {
      Thread.sleep(2000);
    } catch (InterruptedException ex) {
      ex.printStackTrace();
    }
     
    try {
      System.out.println("task運(yùn)行結(jié)果:"+futureTask.get());
    } catch (InterruptedException ex) {
      ex.printStackTrace();
    } catch (ExecutionException ex) {
      ex.printStackTrace();
    }
     
    System.out.println("所有任務(wù)執(zhí)行完畢");
  }
}
class Task implements Callable<Integer>{
  @Override
  public Integer call() throws Exception {
    System.out.println("子線程在執(zhí)行任務(wù)...");
    //模擬任務(wù)耗時(shí)
    Thread.sleep(5000);
    return 1000;
  }
}

執(zhí)行結(jié)果:

子線程在執(zhí)行任務(wù)...
主線程在執(zhí)行任務(wù)...
task運(yùn)行結(jié)果:1000
所有任務(wù)執(zhí)行完畢

總結(jié)

以上就是本文關(guān)于淺談在Java中使用Callable、Future進(jìn)行并行編程的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!

相關(guān)文章

  • 一文詳解Mybatis-plus的介紹與使用

    一文詳解Mybatis-plus的介紹與使用

    Mybatis-Plus?是?MyBatis?的一個(gè)增強(qiáng)工具,專門針對(duì)于傳統(tǒng)MyBatis開(kāi)發(fā)中sql需要手動(dòng)進(jìn)行映射配置繁瑣缺點(diǎn)的一款框架技術(shù)。本文將為大家詳細(xì)講講Mybatis-plus的介紹與使用,感興趣的可以了解一下
    2022-07-07
  • 關(guān)于Java虛擬機(jī)HotSpot

    關(guān)于Java虛擬機(jī)HotSpot

    這篇文章主要介紹了關(guān)于Java虛擬機(jī)HotSpot,在Java類中的一些方法會(huì)被由C/C++編寫(xiě)的HotSpot虛擬機(jī)的C/C++函數(shù)調(diào)用,不過(guò)由于Java方法與C/C++函數(shù)的調(diào)用約定不同,所以并不能直接調(diào)用,需要JavaCalls::call()這個(gè)函數(shù)輔助調(diào)用,下面我們來(lái)看看文章對(duì)內(nèi)容的具體介紹
    2021-11-11
  • Java使用Lua實(shí)現(xiàn)動(dòng)態(tài)擴(kuò)展和腳本自動(dòng)升級(jí)

    Java使用Lua實(shí)現(xiàn)動(dòng)態(tài)擴(kuò)展和腳本自動(dòng)升級(jí)

    Lua是一種輕量級(jí)的腳本語(yǔ)言,常用于游戲開(kāi)發(fā)和嵌入式系統(tǒng)中,這篇文章主要介紹了Java如何調(diào)用Lua實(shí)現(xiàn)動(dòng)態(tài)擴(kuò)展和腳本自動(dòng)升級(jí),感興趣的可以學(xué)習(xí)下
    2023-08-08
  • SpringBoot中注冊(cè)過(guò)濾器的幾種實(shí)現(xiàn)方式

    SpringBoot中注冊(cè)過(guò)濾器的幾種實(shí)現(xiàn)方式

    本文主要介紹了SpringBoot中注冊(cè)過(guò)濾器的幾種實(shí)現(xiàn)方式,主要介紹了三種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • 淺談java如何生成分享海報(bào)工具類

    淺談java如何生成分享海報(bào)工具類

    這篇文章主要介紹了淺談java如何生成分享海報(bào)工具類,想了解分享海報(bào)知識(shí)的同學(xué)不要錯(cuò)過(guò)哦
    2021-04-04
  • JAVA基礎(chǔ)之控制臺(tái)輸入輸出的實(shí)例代碼

    JAVA基礎(chǔ)之控制臺(tái)輸入輸出的實(shí)例代碼

    下面小編就為大家?guī)?lái)一篇JAVA基礎(chǔ)之控制臺(tái)輸入輸出的實(shí)例代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-07-07
  • Spring核心容器之ApplicationContext上下文啟動(dòng)準(zhǔn)備詳解

    Spring核心容器之ApplicationContext上下文啟動(dòng)準(zhǔn)備詳解

    這篇文章主要介紹了Spring核心容器之ApplicationContext上下文啟動(dòng)準(zhǔn)備詳解,ApplicationContext 繼承自 BeanFactory ,其不僅包含 BeanFactory 所有功能,還擴(kuò)展了容器功能,需要的朋友可以參考下
    2023-11-11
  • java利用htmlparser獲取html中想要的代碼具體實(shí)現(xiàn)

    java利用htmlparser獲取html中想要的代碼具體實(shí)現(xiàn)

    這篇文章主要介紹了java利用htmlparser獲取html中想要的代碼具體實(shí)現(xiàn),需要的朋友可以參考下
    2014-02-02
  • 完美解決PermGen space異常的問(wèn)題

    完美解決PermGen space異常的問(wèn)題

    這篇文章主要介紹了完美解決PermGen space異常的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • 使用idea開(kāi)發(fā)Servlet詳細(xì)圖文教程

    使用idea開(kāi)發(fā)Servlet詳細(xì)圖文教程

    這篇文章主要給大家介紹了關(guān)于使用idea開(kāi)發(fā)Servlet的相關(guān)資料,將idea添加servlet的過(guò)程其實(shí)非常簡(jiǎn)單,只需要按照以下幾個(gè)步驟即可完成,需要的朋友可以參考下
    2023-10-10

最新評(píng)論