FutureTask实现超时任务

最近主要在弄一些c/s的东西,以及对接一些外部的接口。
记下一些感觉有用的东西吧。
java在1.5之后又Callable和Future可以获得任务执行完毕后的结果
结合ExecutorService来使用。

使用场景

在调用外部登录接口的时候发现请求过去如果没连上网会一直在请求导致登录界面死机,所以一些连接的请求必须要有一个超时时间,一些耗时的操作的时候也需要一个超时时间来防止死锁导致的资源占用。

使用方法

  ExecutorService executor = Executors.newSingleThreadExecutor();
        FutureTask<PrePickupMailRes> future = new FutureTask<>(() -> {
         ...
         ...
         具体方法,返回的类可以为任意,在泛型中限制 此处返回为自用类举例
            return prePickupMailRes;
        });

        executor.execute(future); //执行
        try {
            PrePickupMailRes prePickupMailRes = future.get(5000, TimeUnit.MILLISECONDS); //取得结果,设置超时时间
        } catch (InterruptedException | ExecutionException | TimeoutException e) {
            future.cancel(true);
        } finally {
            executor.shutdown();
        }

猜你喜欢

转载自blog.csdn.net/chijiandi/article/details/81387959
今日推荐