• 【java】【ExecutorService】【线程池】java 超时返回,异步线程实现超时响应


    今日份代码:

    import java.util.concurrent.Callable;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    import java.util.concurrent.Future;
    import java.util.concurrent.TimeUnit;
    
    /**
     * java实现超时返回
     * 到了规定时间,不管有没有执行结果,我都要响应前端
     *
     * @author xudong.shen
     * @date 2022/03/23
     */
    public class ListTest {
    
        public static void main(String[] args) {
            Callable<String> task = new Callable<String>() {
                @Override
                public String call() throws Exception {
                    //设置执行响应时间的方法体
                    String str = ListTest.sleepJavaTest();
                    System.err.println("不论执行多久,我都在等着打印结果:"+str);
                    return str;
                }
            };
    
            ExecutorService exeservices = Executors.newSingleThreadExecutor();
            Future<String> future = exeservices.submit(task);
            try {
                //设置我最多等 5s,5s后无论如何我都要响应前端
                String result = future.get(5, TimeUnit.SECONDS);
                System.err.println("我在规定时间内返回SUCCESS啦:"+result);
            } catch (Exception e) {
                e.printStackTrace();
                //异常处理的方法
                System.err.println("我在规定时间内没返回FAIL呢:这里是异常处理的方法");
            }
        }
    
        public static String sleepJavaTest() {
    
            try {
                /*java中sleep与wait的区别
                 * 对于sleep方法导致程序暂停执行指定的时间,让出cpu给其他线程。但是它的监控状态依然保持,时间到了就会恢复。
                 * 在sleep方法中,线程不会释放对象锁。
                 * 对于wait方法,线程会放弃对象锁,进入等待次对象的等待锁定池,
                 * 只有针对此对象调用notify()后,本线程才进入对象锁定池的准备。
                 *
                 * 假设我执行了7s
                 */
                Thread.sleep(7000);
                return "当前函数成功的返回";
            } catch (InterruptedException e) {
                e.printStackTrace();
                return "执行异常";
            }
        }
    
    
    
    }
  • 相关阅读:
    counter的使用
    Keras保存模型
    pytorch中F.avg_pool1d()和F.avg_pool2d()
    为什么要进行batchNormalization?
    利用Ajax完成前后端数据传输有关知识(day67)
    ORM中choice参数的设计、Ajax介绍(day66)
    聚合分组查询、F与Q查询、常用字段知识(day65)
    ORM数据库查询操作(单表,多表)(day64)
    CBV源码剖析,模板语法(day63)
    小程序加入购物车抛物线效果
  • 原文地址:https://www.cnblogs.com/sxdcgaq8080/p/16045269.html
Copyright © 2020-2023  润新知