并发编程 Future-ExecutorService

创建线程的2种方式:

  1. 直接继承Thread;
  2. 实现Runnable接口。

这2种方式都有一个缺陷就是:在执行完任务之后无法获取执行结果。

只有通过共享变量或者使用线程通信的方式来达到获取执行结果的效果

 

java.lang.Runnable (只有一个方法void run() )

Modifier and Type

Method and Description

void

run()

当一个实现Runnable接口的对象被用来创建一个线程时,启动这个线程会导致对象的run方法被调用。

 

Callable接口类似于Runnable,因为它们都是为可能由另一个线程执行的实例的类设计的。但是,Runnable不返回结果,也不能抛出已检查的异常。

 

java.util.concurrent.Callable(只有一个方法 V call() throws Exception)

Modifier and Type

Method and Description

V

call()

计算结果,如果无法计算,则抛出异常

Callable一般是和ExecutorService配合来使用的

 

内存一致性效应:

即:(Callable/Runnable )task被提交之前 ——> task被提交给ExecutorService ——> task 执行操作 ——>Future.get()检索task结果

 

ExecutorService可以产生用于跟踪一个或多个异步任务的进度的Future的方法。

 

java.util.concurrent.ExecutorService

public interface ExecutorService extends Executor

 Future

submit(Callable task)

提交一个返回值的task以执行,并返回一个表示该任务未决结果的Future

Future

submit(Runnable task)

提交要执行的Runnable task,并返回表示该任务的Future.

 Future

submit(Runnable task, T result)

提交要执行的Runnable task,并返回表示该任务的Future.

终止时,执行器没有正在执行的任务,没有等待执行的任务,也不能提交新任务。应该关闭未使用的ExecutorService,以便回收其资源。

void

shutdown()

启动有序关闭,在此过程中执行先前提交的任务,但不接受任何新任务。

List

shutdownNow()

尝试停止所有正在积极执行的任务,停止处理等待的任务,并返回等待执行的任务列表。

 

 List>

invokeAll(Collection> tasks)

执行给定的任务,当所有任务都完成时,返回包含状态和结果的Future列表。

 List>

invokeAll(Collection> tasks, long timeout, TimeUnit unit)

执行给定的任务,返回一个Future列表,其中包含所有任务完成或超时结束时的状态和结果

 

Future接口代表异步计算的结果,通过Future接口提供的方法可以查看异步计算是否执行完成,或者等待执行结果并获取执行结果,同时还可以取消执行

如果为了可取消性而使用 Future 但又不提供可用的结果,则可以声明 Future 形式类型、并返回 null 作为底层任务的结果。

java.util.concurrent.Future

Modifier and Type

Method and Description

boolean

cancel(boolean mayInterruptIfRunning)

试图取消此任务的执行.如果任务无法取消(通常因为任务已正常完成),则为false;否则为true

V

get()

如果需要,等待计算完成,然后检索其结果。

V

get(long timeout, TimeUnit unit)

如果需要,则最多等待给定的计算完成时间,然后如果可用,检索其结果。

boolean

isCancelled()

如果此任务在正常完成之前被取消,则返回true。

boolean

isDone()

如果此任务已完成,则返回true。

 

FutureTask是一个可取消的异步计算。该类提供了Future的基本实现,提供了启动和取消计算、查询计算是否完成以及检索计算结果的方法。只有在计算完成后才可检索结果;如果计算尚未完成,get方法将阻塞。一旦计算完成,就不能重新启动或取消计算(除非使用runAndReset()调用计算)。

FutureTask实现了RunnableFuture接口,而RunnableFuture接口继承了Runnable接口和Future接口,所以FutureTask既能当做一个Runnable直接被Thread执行,也能作为Future用来得到Callable的计算结果。

 

 

你可能感兴趣的:(并发编程 Future-ExecutorService)