foreach遍历的底层原理

  • Post author:
  • Post category:其他


foreach遍历集合类型和数组类型底层实现的不同

  • 集合类型的遍历本质是使用迭代器实现的(list,map,set)
  • 数组的遍历是通过for循环来实现的(普通数组)

扩展:

遍历集合的时候移除某个数据:

    ArrayList<Integer> list = new ArrayList<>();
		list.add(1);
		list.add(2);
		list.add(3);
		list.add(4);
		for(int i=0 ;i<list.size();i++){
			if (i==2) {
				list.remove(i);
			}
		}
    System.out.println(list);  //[1, 2, 4]

用foreach的方式会报错,因为底层是用迭代器实现的,迭代器在进行迭代的时候不允许对数据进行增删操作。

            ArrayList<Integer> list = new ArrayList<>();
		list.add(1);
		list.add(2);
		list.add(3);
		list.add(4);
		
		
		
		for (Integer integer : list) {
			if (integer==1) {
				list.remove(integer); //这个地方会报错
			}
		}
		System.out.println(list);

//以上代码会报错,错误提示如下:
Exception in thread "main" java.util.ConcurrentModificationException
	at java.util.ArrayList$Itr.checkForComodification(Unknown Source)
	at java.util.ArrayList$Itr.next(Unknown Source)
	at ListTest.main(ListTest.java:20)



版权声明:本文为ai_goodStudent原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。