zoukankan      html  css  js  c++  java
  • 【java】并发执行ExecutorService的sumbit返回值的顺序问题

    
    

      ArrayList<Future> fl = new ArrayList<Future>();

    for (int i = 0; i < 10; i++) {
      Future<String> future = executorService.submit(new TaskWithResult(i));
      fl.add(future);
    }
    for(int i = 0;i<fl.size();i++){   System.out.printf("future.get() = " + fl.get(i).get());   System.out.println(""); }

    一开始,我以为 executorService.submit中先执行完的任务的返回结果集会存在fl的前面,但是经过测试发现,却并非如此。

    测试代码:

    public void test() throws InterruptedException, ExecutionException{
            ExecutorService executorService = Executors.newCachedThreadPool();
            
            int j = 0;
            @SuppressWarnings("rawtypes")
            ArrayList<Future> fl = new ArrayList<Future>();
            for (int i = 0; i < 10; i++) {
                Future<String> future = executorService.submit(new TaskWithResult(i));
                fl.add(future);
            }
            for(int i = 0;i<fl.size();i++){
                System.out.printf("future.get() = " + fl.get(i).get()); 
                System.out.println("");
            }
            
        }
    
    
    class TaskWithResult implements Callable<String> {  
        private int id;  
        public TaskWithResult(int id) {  
            this.id=id;  
        }  
          
        @Override  
        public String call() throws Exception { 
            ArrayList<String> s = new ArrayList<String>();
            for(int i = 0; i < (10-id)* 10000 ;i++){
                String s1 = String.valueOf(id) + ':' + String.valueOf(i);
                s.add(s1);
            }
            System.out.println("完成: " + id);   
            return String.valueOf(id);  
        }  
    }  

    执行后输入如下:

    完成: 5
    完成: 7
    完成: 6
    完成: 4
    完成: 8
    完成: 9
    完成: 3
    完成: 2
    完成: 1
    完成: 0
    future.get() = 0
    future.get() = 1
    future.get() = 2
    future.get() = 3
    future.get() = 4
    future.get() = 5
    future.get() = 6
    future.get() = 7
    future.get() = 8
    future.get() = 9

    这表明,不管是哪个任务先完成,在返回值列表中的顺序是一样的。这个是如何实现的呢?

    Future<V>代表一个异步执行的操作,通过get()方法可以获得操作的结果,如果异步操作还没有完成,则,get()会使当前线程阻塞。

  • 相关阅读:
    iframe脸面的页面和父页面之间的交互方法
    iframe高度自适应
    获取html元素所在页面的坐标
    自制的几个jquery插件
    将DataTable转换成Json格式
    QL 获取当前日期,年、月、日、周、时、分、秒
    DropdownList异步刷新GridView数据
    图片热区——map的用法
    Chart控件文档
    母版页改变被嵌套的页面中的控件ID的解决方法
  • 原文地址:https://www.cnblogs.com/seyjs/p/7017368.html
Copyright © 2011-2022 走看看