ホームページ  >  記事  >  Java  >  Java マルチスレッド処理における Future の素晴らしい使用例

Java マルチスレッド処理における Future の素晴らしい使用例

黄舟
黄舟オリジナル
2017-10-12 10:12:281602ブラウズ

この記事では主に Java マルチスレッド処理における Future の魔法の使い方を紹介します (ソースコードも添付)。必要な方は参考にしてください。

JavaのFutureは、このスレッドの処理結果を保存する、いつでも結果を取り出すことができるオブジェクトです。どちらの場合でも、フューチャーを離れることはほぼ不可能です。たとえば、アプリケーションがバッチ注文を受け取る場合、その注文を同時に処理する必要がある場合、この問題が発生します。自分でプログラムする場合は非常に面倒ですが、CompletionService を使用してこの問題を解決できます。 CompletionServiceはFutureをキューに集め、結果処理が完了した順にキューに入れることができます。もう 1 つの状況は、何かを同時にクエリする必要がある場合 (クローラーなど)、同時クエリの 1 つの結果が返される限り、クエリに到達したとみなしてその時点でクエリを終了することです。問題を解決するには 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 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。