7.1 任务的取消
任务应该是可取消的:在run的外界可以让其状态从运行变为终止。
需要取消任务的场景:
1、用户取消任务,如点击了“取消”
2、时间timeout限制的任务
3、程序外部事件需要处理。
4、出错
5、关闭、退出、清理
Java中没有原生提供“停止线程”的方法,但可以使用“bool标志位+volatile”的方式来实现,注意list还是需要被锁保护的。
@ThreadSafe
public class PrimeGenerator[......]
7.1 任务的取消
任务应该是可取消的:在run的外界可以让其状态从运行变为终止。
需要取消任务的场景:
1、用户取消任务,如点击了“取消”
2、时间timeout限制的任务
3、程序外部事件需要处理。
4、出错
5、关闭、退出、清理
Java中没有原生提供“停止线程”的方法,但可以使用“bool标志位+volatile”的方式来实现,注意list还是需要被锁保护的。
@ThreadSafe
public class PrimeGenerator[......]
5.1 同步的Collections
JDK中,同步的Collections包含Vector和Hashtable,以及从1.2之后加入的Collections.synchronizedXXX 工厂构造函数生成的类。
这些类都内置了同步措施,确保任何时间只有一个线程能访问public方法。
然而这有一些例外:下标迭代、iteration迭代、foreach、next()、pre()等都是“快速失效的”,即有可能在你调用的过程中其他线程执行了修改,导致抛出异常。
因此,下面只是[......]
第三章 共享对象
在有的业务场景,不仅需要线程安全读写对象,还要让其他线程得知对象状态的更改,这必须由线程同步机制来完成。
3.1 可见性
当某个变量改变时,如果不运用线程同步机制,将无法确保另外的读线程能马上看到修改的结果。
例如下面的代码:
public class NoVisibility {
private static boolean ready;
private static int number;
private static c[......]
第二章 线程安全
2.1 什么是线程安全
定义1:无状态的对象一定是现成安全的。
@ThreadSafe
public class StatelessFactorizer implements Servlet {
public void service(ServletRequest req, ServletResponse resp) {
BigInteger i = extractFromRequest(req);
BigInteger[......]