使用多线程异步循环

时间:2017-08-02 04:11:04

标签: java multithreading

我有嵌套循环。我知道没有办法减少嵌套循环完成所花费的时间。但是我们如何使用多线程或执行器服务更快地完成循环。

例如:

for(String str : ListA){
  for(String str1 : ListB){
     for(String str2 : ListC){
         //do Something
     }
  }
}

所以我理解完成循环需要M N P(其中M,N,P是List的大小)。但是我如何在这里使用多线程并通过执行异步作业更快地完成循环。我想使用Executor Service,因为我正在使用java 7(不能使用Parallel Streams)。

我试过了:

ExecutorService executor = Executors.newFixedThreadPool(10);
for(String str : ListA){
     executor.execute(new Runnable() {
    @Override
    public void run() {
      for(String str1 : ListB){
        for(String str2 : ListC){
         //do Something
        }
      }
    } });
 }

但我相信上面的过程是启动线程10次,但执行相同的事情10次,这不是循环如何工作。请问任何人请建议我如何使用Java中的多线程执行器服务完成此循环?

1 个答案:

答案 0 :(得分:2)

循环足够快,你不必优化它。你正在执行的实际代码//如果有阻塞行为,可能会遇到问题。在这种情况下,您可以执行以下操作

ExecutorService executor = Executors.newFixedThreadPool(10);

List<String> level1 = Arrays.asList("1", "2", "3");
List<String> level2 = Arrays.asList("a", "b", "c");
List<String> level3 = Arrays.asList("x", "y", "z");
for(String l1 : level1){
  for(String l2 : level2){
     for(String l3 : level3){
        executor.execute(new Runnable() {
            @Override
            public void run() {
                get("http://foo.com/"+l1+"/"+l2+"/"+l3);
            }
        });
     }
  }
}