方式三:(原始做法)用集合的size(),get(index)方法再用for循环去遍历操作内容
//报错代码(ConcurrentModificationException)代码如下:
-
public
class Test01{
-
public static void main(String[] args) {
-
// 创建集合对象
-
Collection c =
new ArrayList();
-
// 添加元素
-
c.add(
“hello”);
-
c.add(
“world”);
-
c.add(
“java”);
-
// 我们可以通过遍历来获取集合中的每一个元素,然后进行比较即可
-
Iterator it = c.iterator();
-
while (it.hasNext()) {
-
String s = (String) it.next();
-
if (s.equals(
“java”)) {
-
c.add(
“android”);
-
}
-
}
-
System.out.println(c);
-
}
-
}
//解决方案方式2 代码如下:
-
public
class Test02{
-
public static void main(String[] args) {
-
// 创建集合对象
-
List c =
new ArrayList();
-
// 添加元素
-
c.add(
"hello");
-
c.add(
"world");
-
c.add(
"java");
-
ListIterator lit = c.listIterator();
-
while(lit.hasNext()) {
-
String s = (String)lit.next();
-
if(s.equals(
"java")) {
-
lit.add(
"android");
//直接用迭代器进行操作修改
-
}
-
}
-
System.out.println(c);
-
}
-
}
注:使用增强for循环同样可能会出现这样的异常,因为其底层同样也是使用了迭代器。
关于for循环和迭代器的比较:
记录的存取方式有两种:一种是顺序存储,另一种是链接存储 对于顺序存储的记录可以根据其下标找到对应的记录,而链接存储(拿单链表为例) 则必须找到其前一个记录的位置才能够找到本记录。 所以for循环便于访问顺序存储的记录,比如数组等 而迭代则更适用于链接存储的记录,虽然Java中有些底层通过链接存储原理实现的集合 也可以通过下标获取指定的记录,但是其每次都必须从链表头开始查找记录,这样会影响查找的效率。
原文链接:https://blog.csdn.net/weixin_39494923/article/details/76599767