• 多线程,超时处理


    1.使用线程池ExecutorService exec = Executors.newFixedThreadPool(1);

    2.根据线程返回的结果Future,进行相应处理

    demo如下:

    package com.test;

    import java.util.concurrent.Callable;
    import java.util.concurrent.ExecutionException;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.Future;
    import java.util.concurrent.TimeUnit;
    import java.util.concurrent.TimeoutException;

    public class TimeOutTest {

        public static void main(String[] args) {
            System.out.println("程序开始");
            final ExecutorService exec = Executors.newFixedThreadPool(1);

            Callable<String> call = new Callable<String>() {
                public String call() throws Exception {
                    // 开始执行耗时操作
                    Thread.sleep(1000 * 3);
                    System.out.println("程序早结束了,已经没用了。");
                    return "线程执行完成.";
                }
            };
            Future<String> future = null;
            try {
                future = exec.submit(call);
                String obj = future.get(1000 * 1, TimeUnit.MILLISECONDS); // 任务处理超时时间设为 1 秒
                System.out.println("任务成功返回:" + obj);
            } catch (TimeoutException ex) {
                System.out.println("处理超时啦....");
                if(future!=null){
                    future.cancel(true);
                }
            } catch (Exception e) {
                System.out.println("处理失败.");
            }finally{
                System.out.println("关闭线程池");
                // 关闭线程池
                exec.shutdown();
            }
            System.out.println("程序结束");
        }
    }
     

    转载于:https://my.oschina.net/sky2008/blog/904299

  • 相关阅读:
    Ubuntu安装adobe的Source Code Pro
    Oracle实现主键自增的几种方式
    Oracle主键自增
    activity 根据流程实例ID删除流程实例、删除流程部署
    解决报错:错误1130- Host xxx is not allowed to connect to this MariaDb server
    Idea-每次修改JS文件都需要重启Idea才能生效解决方法
    html中<a href> </a>的用法
    Mysql8_数据库基础操作
    java反射及Method的Invoke方法(转载)
    oracle查询数据插入时间
  • 原文地址:https://www.cnblogs.com/twodog/p/12140517.html
Copyright © 2020-2023  润新知