java并发中ExecutorService的使用
文章目录
java并发中ExecutorService的使用 ExecutorService是java中的一个异步执行的框架,通过使用ExecutorService可以方便的创建多线程执行环境。 本文将会详细的讲解ExecutorService的具体使用。 创建ExecutorService通常来说有两种方法来创建ExecutorService。 第一种方式是使用Executors中的工厂类方法,例如:
除了newFixedThreadPool方法之外,Executors还包含了很多创建ExecutorService的方法。 第二种方法是直接创建一个ExecutorService, 因为ExecutorService是一个interface,我们需要实例化ExecutorService的一个实现。 这里我们使用ThreadPoolExecutor来举例:
为ExecutorService分配TasksExecutorService可以执行Runnable和Callable的task。其中Runnable是没有返回值的,而Callable是有返回值的。我们分别看一下两种情况的使用:
将task分配给ExecutorService,可以通过调用xecute(),submit(),invokeAny(),invokeAll()这几个方法来实现。 execute() 返回值是void,他用来提交一个Runnable task。
submit() 返回值是Future,它可以提交Runnable task,也可以提交Callable task。 提交Runnable的有两个方法:
第一个方法在返回传入的result。第二个方法返回null。 再看一下callable的使用:
invokeAny() 将一个task列表传递给executorService,并返回其中的一个成功返回的结果。
invokeAll() 将一个task列表传递给executorService,并返回所有成功执行的结果:
关闭ExecutorService如果ExecutorService中的任务运行完毕之后,ExecutorService不会自动关闭。它会等待接收新的任务。如果需要关闭ExecutorService, 我们需要调用shutdown() 或者 shutdownNow() 方法。 shutdown() 会立即销毁ExecutorService,它会让ExecutorServic停止接收新的任务,并等待现有任务全部执行完毕再销毁。
shutdownNow()并不保证所有的任务都被执行完毕,它会返回一个未执行任务的列表:
oracle推荐的最佳关闭方法是和awaitTermination一起使用:
先停止接收任务,然后再等待一定的时间让所有的任务都执行完毕,如果超过了给定的时间,则立刻结束任务。 Futuresubmit() 和 invokeAll() 都会返回Future对象。之前的文章我们已经详细讲过了Future。 这里就只列举一下怎么使用:
ScheduledExecutorServiceScheduledExecutorService为我们提供了定时执行任务的机制。 我们这样创建ScheduledExecutorService:
executorService的schedule方法,可以传入Runnable也可以传入Callable:
还有两个比较相近的方法:
两者的区别是前者的period是以任务开始时间来计算的,后者是以任务结束时间来计算。 ExecutorService和 Fork/Joinjava 7 引入了Fork/Join框架。 那么两者的区别是什么呢? ExecutorService可以由用户来自己控制生成的线程,提供了对线程更加细粒度的控制。而Fork/Join则是为了让任务更加快速的执行完毕。 本文的代码请参考https://github.com/ddean2009/learn-java-concurrency/tree/master/ExecutorService 更多教程请参考 flydean的博客 (编辑:北几岛) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |