Java并发课程之FutureTask

Java并发课程之FutureTask

简介: 在Java中一般通过继承Thread类或者实现Runnable接口这两种方式来创建多线程,但是这两种方式都有个缺陷,就是不能在执行完成后获取执行的结果,因此Java 1.5之后提供了Callable和Future接口,通过它们就可以在任务执行完毕之后得到任务的执行结果。FutureTask可用于异步获取执行结果或取消执行任务的场景。通过传入Runnable或者Callable的任务给FutureTask,直接调用其run方法或者放入线程池执行,之后可以在外部通过FutureTask的get方法异步获取执行结果,因此,FutureTask非常适合用于耗时的计算,主线程可以在完成自己的任务后,再去获取结果。另外,FutureTask还可以确保即使调用了多次run方法,它都只会执行一次Runnable或者Callable任务,或者通过cancel取消FutureTask的执行等。

基本原理:
1、JVM中定义了Callable接口,声明一个可以获取接口的任务,Future在构造器中声明封装一个Callable实例。
2、调用Future接口的get方法需要阻塞当前线程等待任务结果,FutureTask中封装了一个等待队列,当某线程调用get方法后,会将该线程添加到等待队列,并调用LockSupport.park阻塞当前线程
3、FutureTask执行时,run方法中会调用Callable实例获取任务结果完成后记录该结果,run方法执行完毕后唤醒等待队列中所有阻塞线程。
4、等待队列中的线程被唤醒后会去FutureTask中获取任务执行结果。

本文参考
本文主要参考以下文章,谨以技术分享为目的,将此文搬到CSDN上,如有侵权问题请联系本人,乐于分享提高。
作者: 立志19
链接:https://www.jianshu.com/p/27d65f844e4a

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值