第9章 线程
第
48
条:对共享可变数据的同步访问
Synchronized
关键字可以保证在同一时刻,只有一个线程在执行同一条语句,或者同一个代码块。
同步不仅可以阻止一个线程看到对象看到处于不一致的状态中,它还可以保证通过一系列看似顺序执行的状态转变序列,对象从一种一致的状态变迁到另一种一致的状态。
为了在线程之间可靠的通信,以及为了互斥访问,同步是需要的。
Volatile
修饰符可以保证一个线程在读取一个域的时候都将会看到最近刚刚被写入的值。
第
49
条:避免使用过多的同步
在一个被同步的区域内部,不要调用一个可被改写的公有或受保护的方法
通常,在同步区域内你应该做尽可能少的工作
如果一个类或者一个静态方法依赖于一个可变的静态域,那么它必须在内部进行同步,即使它往往只用于单个线程。
第
50
条:永远不要在循环的外面调用
wait
在等待之前测试条件,如果条件成立的话则跳过等待,这对于确保活性是必要的。
在等待之后测试条件,如果条件不成立的话继续等待,这对于确保安全性是必要的。
总是在一个
while
循环中调用
wait
,并且使用标准的模式。一般情况下,你应该使用
notifyAll
优先于
notify
。
第
51
条:不要依赖于线程调度器
不要依赖
Thread.yield
或者线程优先级。
第
52
条:线程安全性的文档化
第
53
条:避免使用线程组
第
10
章
序列化
序列化技术为远程通信提供了标准的线路层对象表示,也为
javaBean
组件结构提供了标准的永久数据格式。
第
54
条:谨慎的实现
Serializable
提供一个可访问的无参数构造函数,该设计方案允许(但不要求)子类实现
Serializable
。
第
55
条:考虑使用自定义的序列化形式
transient Java语言的关键字,用来表示一个域不是该对象串行化的一部分。当一个对象被串行化的时候,transient型变量的值不包括在串行化的表示中,然而非transient型的变量是被包括进去的。
第
56
条:保护性的编写
readObject
方法
当一个对象被反序列化的时候,对于客户不应该拥有的对象引用,如果哪个域包含了这样的对象引用,则必须要做保护性拷贝,这是非常重要的。
对于每一个可序列化的非可变类,如果它包含了私有的可变组件,那么在它的
readObject
方法中,必须要对这些组件进行保护性拷贝。
对于非
final
的可序列化的雷,在
readObject
方法和构造函数之间还有类似的地方,
readObject
方法不可以调用可被改写的方法,无论是直接调用还是间接调用都不可以。
第
57
条:必要时提供一个
readResolve
方法
readResolve
方法不仅仅对于
singleton
对象是必要的,而且对于所有其他的实例受控的类也是必需的。