[英]Is it thread-safe to iterate a HashMap object concurrently?
如果多个线程同时迭代HashMap
对象而不修改它 ,那么竞争条件是否存在?
没有竞争,如果你可以保证在迭代时没有其他线程会修改这个HashMap。
不,那很好。 只要所有读取与所有写入同步,并且所有写入彼此同步,并发读取就没有坏处; 因此,如果根本没有写入,则所有并发访问都是安全的。
它会好起来的。 但是如果任何线程添加或删除一个项,这将在任何其他只是迭代HashMap的线程中抛出异常(实际上是任何集合)
如果要重复迭代Map,可能会发现迭代数组副本的速度要快一些。
private final HashMap<String, String> properties = new HashMap<String, String>();
private volatile Map.Entry<String, String>[] propertyEntries = null;
private void updatePropertyEntries() {
propertyEntries = properties.entrySet().toArray(new Map.Entry[properties.size()]);
}
{
// no objects created
for (Map.Entry<String, String> entry : propertyEntries) {
}
}
顺便说一句:你可以让一个线程修改/替换propertyEntries,同时在这个模式的许多线程中进行迭代。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.