Java 集合 线程安全
2009-12-29 15:06
363 查看
线程安全的集合包含2个问题
1.多线程并发修改一 个 集合 怎么办?
2.如果迭代的过程中 集合 被修改了怎么办?
a.一个线程在迭代,另一个线程在修改
b.在同一个线程内用同一个迭代器对象进行迭代、修改、迭代、修改. . .
共有有3种解决方案
1.用老的Vector/Hashtable类,上面2个问题都不用担心。
Vector/Hashtable所提供的所有方法都是 synchronized的。如果 迭代的过程中数据结构被修改了,迭代器可以反映最新的修改,也不会抛异常。但这种方法效率低下,不建议使用。
2.使用ArrayList/HashMap和同步包装器
可用 同步包装器使容器变成线程安全的
Java代码
1. List synchArrayList = Collections.synchronizedList(new ArrayList());<br>
2. Map synchHashMap = Collections.synchronizedMap(new HashMap())<br>
List synchArrayList = Collections.synchronizedList(new ArrayList());
Map synchHashMap = Collections.synchronizedMap(new HashMap())
如果要迭代,需要这样
Java代码
1. synchronized (synchHashMap)<br>
2. {<br>
3. Iterator iter = synchHashMap.keySet().iterator();<br>
4. while (iter.hasNext()) . . .;<br>
5. }<br>
synchronized (synchHashMap)
{
Iterator iter = synchHashMap.keySet().iterator();
while (iter.hasNext()) . . .;
}
注意上面的代码每次进入同步块都生成了一个新的迭代器。如果你还用老的迭代器,2b的情况就可能发生,你会收到一个ConcurrentModificationException。
3.用java5.0新加入的ConcurrentLinkedQueue、ConcurrentHashMap、CopyOnWriteArrayList 和 CopyOnWriteArraySet
对这些集合进行并发修改是安全的。
针对2b的问题,迭代器既不抛异常,也不会反映新的修改。就是说你迭代的是生成迭代器时的容器,不是最新的容器。
转载自:http://kang.javaeye.com/blog/364457
1.多线程并发修改一 个 集合 怎么办?
2.如果迭代的过程中 集合 被修改了怎么办?
a.一个线程在迭代,另一个线程在修改
b.在同一个线程内用同一个迭代器对象进行迭代、修改、迭代、修改. . .
共有有3种解决方案
1.用老的Vector/Hashtable类,上面2个问题都不用担心。
Vector/Hashtable所提供的所有方法都是 synchronized的。如果 迭代的过程中数据结构被修改了,迭代器可以反映最新的修改,也不会抛异常。但这种方法效率低下,不建议使用。
2.使用ArrayList/HashMap和同步包装器
可用 同步包装器使容器变成线程安全的
Java代码
1. List synchArrayList = Collections.synchronizedList(new ArrayList());<br>
2. Map synchHashMap = Collections.synchronizedMap(new HashMap())<br>
List synchArrayList = Collections.synchronizedList(new ArrayList());
Map synchHashMap = Collections.synchronizedMap(new HashMap())
如果要迭代,需要这样
Java代码
1. synchronized (synchHashMap)<br>
2. {<br>
3. Iterator iter = synchHashMap.keySet().iterator();<br>
4. while (iter.hasNext()) . . .;<br>
5. }<br>
synchronized (synchHashMap)
{
Iterator iter = synchHashMap.keySet().iterator();
while (iter.hasNext()) . . .;
}
注意上面的代码每次进入同步块都生成了一个新的迭代器。如果你还用老的迭代器,2b的情况就可能发生,你会收到一个ConcurrentModificationException。
3.用java5.0新加入的ConcurrentLinkedQueue、ConcurrentHashMap、CopyOnWriteArrayList 和 CopyOnWriteArraySet
对这些集合进行并发修改是安全的。
针对2b的问题,迭代器既不抛异常,也不会反映新的修改。就是说你迭代的是生成迭代器时的容器,不是最新的容器。
转载自:http://kang.javaeye.com/blog/364457
相关文章推荐
- Java Collection 集合线程安全方法
- 线程安全的集合类(java并发编程第5章)
- Java 集合 构建线程安全
- Java多线程三(线程安全的集合及java.util.concurrent包的锁)
- Java基础之集合框架--Collections.synchronizedList() 线程安全的List
- 详解java各种集合的线程安全
- java创建线程安全的集合
- Java中线程安全集合的使用小结
- Java 集合线程安全
- Java集合中那些类是线程安全的
- Java集合中线程安全的类
- Java多线程:线程安全和非线程安全的集合对象
- Java多线程:线程安全和非线程安全的集合对象
- Java集合中那些类是线程安全的
- java各种集合的线程安全
- java 线程安全集合
- java并发实战第六章(2)非阻塞式线程安全列表与一般List集合多线程情况下的比较
- java中线程安全的集合
- Java集合中那些类是线程安全的
- Java集合中那些类是线程安全的