Future的API使用

  • get() 方法是阻塞得
  • get(10,TimeUnit.SECONDS) get 的超时方法,线程里面并不会死掉
  • isDone() 判断有没有做完
  • cancel() 取消(代码里详细记录)
public static void main(String[] args) throws ExecutionException, InterruptedException, TimeoutException {

        //testInvokeAny();
        testGet();
    }

    public static void testGet() throws ExecutionException, InterruptedException, TimeoutException {
        ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) Executors.newCachedThreadPool();

        Future<Integer> future = threadPoolExecutor.submit(() -> {
            try {
                TimeUnit.SECONDS.sleep(5);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return 10;
        });

        System.out.println("-------------------");


        Thread callThread = Thread.currentThread();
        new Thread(() -> {
            try {
                TimeUnit.SECONDS.sleep(1);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            // 打断得是主线程
            callThread.interrupt();
        }).start();

        // get 方法是阻塞得
        //future.get(10,TimeUnit.SECONDS); // 这是带具有超时时间得获取(线程还未关闭线程)
        Integer result = future.get();
        System.out.println(result);
    }


    public static void testIsDone(){
        ThreadPoolExecutor threadPoolExecutor = (ThreadPoolExecutor) Executors.newCachedThreadPool(
                new ThreadFactory() {
                    @Override
                    public Thread newThread(Runnable r) {
                        Thread thread = new Thread(r);
                        thread.isDaemon();
                        return thread;
                    }
                }
        );

        Future<Integer> future = threadPoolExecutor.submit(() -> {
            try {
                TimeUnit.SECONDS.sleep(5);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return 10;
        });

        // 正常情况下,就是判断任务是否已经完成
        // 异常情况下,出现问题也是 完成
        System.out.println( future.isDone());

        /**
         * try to cancel fail
         * 1: 任务已经完成
         * 2:任务已经取消
         *
         * 取消任务方式 (取消了,拿不到值了)
         * 1:配合
         *  while(!Thread.isTerrupted()){
         *
         *  }
         *  2: 比较流氓的方式 (让整个线程都死掉)
         *              new ThreadFactory() {
         *                     @Override
         *                     public Thread newThread(Runnable r) {
         *                         Thread thread = new Thread(r);
         *                         thread.isDaemon();
         *                         return thread;
         *                     }
         *                 }
         *
         */
        boolean flag = future.cancel(true);

    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
future包是R语言中用于实现并行计算的一个高级包。它提供了一组通用的、面向未来的并行计算工具,可以用于在本地计算机、远程计算机和云计算环境中实现高性能的并行计算。future包的主要特点包括: 1. 易于使用future包提供了简单的API,可以轻松地将串行代码转换为并行代码,而不需要了解底层的并行计算架构。 2. 跨平台支持:future包支持在不同的操作系统和计算环境中进行并行计算,包括本地计算机、远程计算机和云计算环境。 3. 可扩展性:future包支持在多台计算机上进行并行计算,可以轻松地扩展计算资源,以满足不同大小和复杂度的计算任务。 4. 高性能:future使用先进的并行计算技术,可以大大提高计算速度和效率。 具体来说,使用future包实现并行计算的步骤如下: 1. 安装future包: ```r install.packages("future") ``` 2. 加载future包: ```r library(future) ``` 3. 配置计算资源,这里以使用8个CPU核心为例: ```r plan(multiprocess, workers = 8) ``` 4. 执行并行计算,这里以使用lapply函数为例: ```r x <- 1:1000 result <- future_lapply(x, sqrt) ``` 在这个例子中,我们使用了plan函数来配置计算资源,使用multiprocess方法并设置了8个工作进程。然后,我们使用future_lapply函数将sqrt函数应用于x向量中的每个元素,以实现并行计算。最后,我们将结果存储在result列表中。 需要注意的是,future包可以与其他R包和函数一起使用,可以轻松地将串行代码转换为并行代码,以提高计算速度和效率。同时,future包还支持在远程计算机和云计算环境中进行并行计算,可以根据具体需求选择不同的计算资源进行并行计算。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值