首頁  >  文章  >  Java  >  Java多執行緒處理中Future的妙用實例

Java多執行緒處理中Future的妙用實例

黄舟
黄舟原創
2017-10-12 10:12:281588瀏覽

這篇文章主要介紹了淺談Java多執行緒處理中Future的妙用(附源碼),還是比較不錯的,需要的朋友可以參考下。

java 中Future是一個未來對象,裡面保存這線程處理結果,它像一個提貨憑證,拿著它你可以隨時去提取結果。在兩種情況下,離開Future幾乎很難辦。一種情況是拆分訂單,例如你的應用程式收到一個批量訂單,此時如果要求最快的處理訂單,那麼需要並發處理,並發的結果如果收集,這個問題如果自己去編程將非常繁瑣,此時可以使用CompletionService解決這個問題。 CompletionService將Future收集到一個佇列裡,可以依照結果處理完成的先後順序進隊。另外一種情況是,如果你需要並發去查詢一些東西(例如爬蟲),並發查詢只要有一個結果返回,你就認為查詢到了,並且結束查詢,這時也需要用CompletionService和Future來解決。直接上程式碼更直覺:


import java.util.ArrayList;
import java.util.List;
import java.util.Random;
import java.util.concurrent.Callable;
import java.util.concurrent.CompletionService;
import java.util.concurrent.ExecutorCompletionService;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class CompletionServiceTest {
  static int numThread =100;
  static ExecutorService executor = Executors.newFixedThreadPool(numThread);
  public static void main(String[] args) throws Exception{
    //data表示批量任务
    int[] data =new int[100];
    for(int i=1;i<100000;i++){
      int idx =i % 100;
      data[idx] =i;
      if(i%100==0){
        testCompletionService(data);
        data =new int[100];
      }
    }
  }
  private static void testCompletionService(int [] data) throws Exception{    
    CompletionService<Object> ecs = new ExecutorCompletionService<Object>(executor);
    for(int i=0;i<data.length;i++){
      final Integer t=data[i];
      ecs.submit(new Callable<Object>() {
        public Object call() {
          try {
            Thread.sleep(new Random().nextInt(1000));
          } catch (InterruptedException e) {
            e.printStackTrace();
          }
          return t;
        }
      });
    }
    //CompletionService会按处理完后顺序返回结果
    List<Object> res =new ArrayList<Object>();
    for(int i = 0;i<data.length;i++ ){
      Future<Object> f = ecs.take();
      res.add(f.get());
    }       
    System.out.println(Thread.currentThread().getName()+":"+res);
  }
  private static void testBasicFuture(int [] data) throws Exception{   
    List<Future<Object>> res =new ArrayList<Future<Object>>();
    for(int i=0;i<data.length;i++){
      final Integer t=data[i];
      Future<Object> future=executor.submit(new Callable<Object>() {
        public Object call() {
          return t;
        }
      });
      res.add(future);
    }   
    for(int i = 0;i<res.size();i++ ){
      Future<Object> f = res.get(i);
      Object rObject =f.get();
      System.out.print(":"+rObject);
    }       
    System.out.println("LN");
  }
}

總結

#

以上是Java多執行緒處理中Future的妙用實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn