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中获取任务执行结果。
本文参考
本文主要参考以下文章,谨以技术分享为目的,将此文搬到优快云上,如有侵权问题请联系本人,乐于分享提高。
作者: 立志19
链接:https://www.jianshu.com/p/27d65f844e4a