java并发编程实战-基础构建模块1

来源:互联网 发布:编程语言实现模式 pdf 编辑:程序博客网 时间:2024/05/17 12:54

1,委托是创建线程安全类的一个最有效的策略,只需让现有的线程安全类管理所有的状态即可。

2,同步容器类

  2.1,同步容器类包括Vector和Hashtable。
  2.3,同步容器是线程安全的类,并不保证在程序运行中一定是正常的。例如迭代不可靠问题:在迭代中如果有其他线程删除了容器中的元素,那么就可能会导致数组越界异常,这异常并不意味着容器不是线程安全的,容器的状态仍然是有效的,而且抛出的数组越界异常也与其规范保持一致。
  2.4,关于容器迭代,在设计同步容器的迭代器时并没有考虑到并发修改问题,并且他们表现出的行为是“及时失败”(fail-fast)的。如果迭代期间计数器被修改了,那么hasNext和next将抛出异常ConcurrentModificationException。
  2.5,如果希望容器在迭代时绝对的线程安全,只能在迭代外层持有容器的锁,这将意味着在容器迭代期间,其他线程时无法访问容器的,这将对程序性能带来影响,也可能带来更加复杂的并发问题,如死锁。
  2.6,对于容器迭代另一个可选的方案是克隆,将副本封闭在线程内,这样做的利弊不同,因为封闭在线程内的副本能够达到线程安全的需求,但是程序性能还是要取决于容器的大小,因为克隆容器存在显著的性能开销
  2.7,有时候容器的迭代会隐藏起来,如调用容器的toString函数,容器会迭代各个元素并调用其toStrig函数。容器的hashCode,equals,containsAll,removeAll,retainAll等方法都可能隐式的对容器进行迭代