zoukankan      html  css  js  c++  java
  • FutureTask 测试用例

    package currentTest.BlockingQueue;
    
    import java.util.concurrent.Callable;
    import java.util.concurrent.ExecutionException;
    import java.util.concurrent.FutureTask;
    
    /**
     * 测试FutureTask的用法,如果不想分支线程阻塞主线程,又想取得分支线程的执行结果,就用FutureTask
     * 
     * @author zhailzh
     * 
     */
    public class FutureTaskTest {
    
        /**
         * @param args
         */
        public static void main(String[] args) {
            CountNum cn = new CountNum(0);
            // FutureTask<Integer> 这里的表示返回的是Integer
            FutureTask<Integer> ft = new FutureTask<Integer>(cn);
            Thread td = new Thread(ft);
            System.out.println("futureTask执行计算:" + System.currentTimeMillis());
            td.start();
            System.out.println("main 主线程可以做些其他事情" + System.currentTimeMillis());
            try {
                // futureTask的get方法会阻塞,知道可以取得结果为止
                Integer result = ft.get();
                System.out.println("计算的结果是:" + result);
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (ExecutionException e) {
                e.printStackTrace();
            }
            System.out.println("取得分支线程执行的结果后,主线程可以继续处理其他事项");
        }
    
    }
    
    class CountNum implements Callable {
        private Integer sum;
    
        public CountNum(Integer sum) {
            this.sum = sum;
        }
    
        public Object call() throws Exception {
            for (int i = 0; i < 100; i++) {
                sum = sum + i;
            }
            // 休眠5秒钟,观察主线程行为,预期的结果是主线程会继续执行,到要取得FutureTask的结果是等待直至完成
            Thread.sleep(3000);
            System.out.println("futureTask 执行完成" + System.currentTimeMillis());
            return sum;
        }
    
    }

     每日一戒:

    201211714208734

  • 相关阅读:
    文件操作实例加强
    文件操作的一般基础操作
    列表与if语句的结合
    难题记录
    字典,集合,列表混合使用需注意:
    列表的一些难度操作
    字符串知识巩固
    and与or的用法
    AngularJS中的过滤器
    NodeJS中的静态资源管理服务
  • 原文地址:https://www.cnblogs.com/zhailzh/p/3928543.html
Copyright © 2011-2022 走看看