1. volatile关键字
2. 原子类:AtomicInteger
3. 线程本地存储
(38)21.3.8 线程本地存储---Java编程思想之并发笔记
4. 在阻塞时终结任务:
ExecutorService
shutdownNow :终结所有阻塞的任务
List<Runnable> shutdownNow()
-
试图停止所有正在执行的活动任务,暂停处理正在等待的任务,并返回等待执行的任务列表。
无法保证能够停止正在处理的活动执行任务,但是会尽力尝试。例如,通过
Thread.interrupt()
来取消典型的实现,所以任何任务无法响应中断都可能永远无法终止。 -
-
-
返回:
- 从未开始执行的任务的列表 抛出:
-
SecurityException
- 如果安全管理器存在并且关闭,此 ExecutorService 可能操作某些不允许调用者修改的线程(因为它没有保持RuntimePermission
("modifyThread")),或者安全管理器的 checkAccess 方法拒绝访问。
submit :终结指定的阻塞任务
<T> Future<T> submit(Callable<T> task)
-
提交一个返回值的任务用于执行,返回一个表示任务的未决结果的 Future。该 Future 的
get 方法在成功完成时将会返回该任务的结果。
如果想立即阻塞任务的等待,则可以使用 result = exec.submit(aCallable).get(); 形式的构造。
注:
Executors
类包括了一组方法,可以转换某些其他常见的类似于闭包的对象,例如,将PrivilegedAction
转换为Callable
形式,这样就可以提交它们了。 -
-
-
参数:
-
task
- 要提交的任务
返回:
- 表示任务等待完成的 Future 抛出:
-
RejectedExecutionException
- 如果任务无法安排执行 -
NullPointerException
- 如果该任务为 null
-