标签:大量 数据 代码 ringbuf 读书 其他 影响 数组 builder
避免过度同步
为了避免活性失败和安全性失败,再一个被同步的方法或者代码快中,永远不要放弃对客户端的控制。
因为外来的,属于不可控的
将外来方法调用移出同步的代码快。
建立快照
使用并发集合,CopyOnWriteArayList。属于ArrayList的变体,通过拷贝整个底层数组,在这里实现所有的写操作。由于内部数据用于不改动,因此迭代不需要锁定,速度也非常快。但如果大量使用,性能将大受影响。
在同步区域之外被调用的外来方法被称作开放调用。
除了可以避免思索之外,开放调用还可以极大地增加并发性。外来方法的运行时间可能会任意长。如果在同步区域内调用外来方法,其他线程对受保护资源的访问就会遭到不必要的拒绝。
如果一个可变的类要并发使用,应该使这个类变成使线程安全的,通过内部同步,你还可以获得明显比从外部锁定整个对象更高的并发性。
StringBuffer代替StringBuilder。
如果在内部同步了类,就可以使用不同的方法来实现高并发性,例如分拆锁、分离锁、非阻塞并发控制。
如果方法修改了静态域,必须同步对这个域的访问,即使它往往只用于单个线程。
Effective java 第十章 并发 避免过度同步 读书笔记
标签:大量 数据 代码 ringbuf 读书 其他 影响 数组 builder
原文地址:http://www.cnblogs.com/carrier/p/7271648.html