歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> Java中的Callable和Future的使用和困惑

Java中的Callable和Future的使用和困惑

日期:2017/3/1 10:34:34   编辑:Linux編程

Java中還提供了可以返回值的線程池,例子如下:

[java]
  1. import java.util.concurrent.Callable;
  2. import java.util.concurrent.ExecutionException;
  3. import java.util.concurrent.ExecutorService;
  4. import java.util.concurrent.Executors;
  5. import java.util.concurrent.Future;
  6. public class CallableAndFuture {
  7. /**
  8. * @param args
  9. */
  10. public static void main(String[] args) {
  11. ExecutorService threadPool = Executors.newSingleThreadExecutor();
  12. Future<String> future = threadPool.submit(new Callable<String>(){
  13. @Override
  14. public String call() throws Exception {
  15. Thread.sleep(3000);
  16. return "future";
  17. }
  18. });
  19. try {
  20. System.out.println("waiting...");
  21. System.out.println(future.get());
  22. } catch (InterruptedException e) {
  23. e.printStackTrace();
  24. } catch (ExecutionException e) {
  25. e.printStackTrace();
  26. }
  27. }
  28. }

future.get()結果出來之前,要等待一會

future.get(300, TimeUnit.MILLISECONDS);然而這個如果在規定的時間內沒有完成,則停止,並且跑出超時異常

還有需要注意的地方,Callable中的泛型和call方法的類型一直,並且還要和Future的泛型類型一致。

下面的例子是,可以返回多個Future對象

[java]
  1. //創建線程池
  2. ExecutorService pool = Executors.newFixedThreadPool(10);
  3. //創建CompletionService實例
  4. CompletionService<Integer> completionService = new ExecutorCompletionService<Integer>(pool);
  5. //提交任務
  6. for(int i = 0;i < 10; i++){
  7. final int index = i;
  8. completionService.submit(new Callable<Integer>(){
  9. @Override
  10. public Integer call() throws Exception {
  11. return index;
  12. }
  13. });
  14. }
  15. //獲得結果
  16. for(int i = 0;i<10;i++){
  17. try {
  18. Future<Integer> future2 = completionService.take();
  19. System.out.println(future2.get());
  20. } catch (InterruptedException e) {
  21. e.printStackTrace();
  22. } catch (ExecutionException e) {
  23. e.printStackTrace();
  24. }
  25. }
  26. }

不知道用在什麼地方,業務需求沒有碰到過這種情況

Copyright © Linux教程網 All Rights Reserved