我正在学习关于快速失败和失败安全迭代器,我有这个问题。我不确定我的理解是否正确。
Vector是Java中同步的线程安全集合对象。所以当我试图得到向量的迭代器时,它是一个失败的快速迭代器,这意味着。。当我在向量对象上使用这个迭代器以及对向量所做的任何更改时,它将抛出ConcurrentModificationExeption。但是,因为vector是线程安全的,所以应该为它提供故障安全迭代器。
为什么在向量的Java中不是这样。与concurrentHashMap一样,它提供了线程安全迭代器。
发布于 2017-05-03 14:45:35
是的,向量是线程安全,向量的迭代是失败的。safe.It是一个遗留类,它是在1.0版本中引入的,后来.Sun人员对其进行了难以处理的工程,并将其添加到List接口中,因此我们可以使用List接口以及向量的所有方法。如果我们将使用迭代器迭代向量对象,那么它将抛出concurrentModificationException。但是如果我们将使用枚举接口迭代向量,那么它将不会抛出任何并发修改Exception.Example :在这个示例中,主线程是迭代向量的元素,子线程是更新现有的向量对象,而我们不会得到任何concurrentModificationException
public class MyThread extends Thread{
static Vector<String> vector = new Vector<>();
public static void main(String[] args) {
vector.add("Sachine");
vector.add("Rahul");
vector.add("Virat");
vector.add("Dhoni");
vector.add("Manish");
MyThread t = new MyThread();
t.start();
Enumeration<String> it = vector.elements();
while (it.hasMoreElements()) {
String name = (String) it.nextElement();
System.out.println(name);
}
System.out.println(vector);
}
@Override
public void run() {
vector.add("Shikhar");
}}
https://stackoverflow.com/questions/32685141
复制相似问题