Java基础之增强型for循环

Java基础之增强型for循环目录增强型for循环语法:for(ElementTypeelement:arrayName){};增强for循环的原理增强型for循环注意事项增强型for循环语法:for(ElementTypeelement:arrayName){};举个例子:(1)int[]numArray={1,2,3,4,5,6};for(inti:numArray…

大家好,又见面了,我是你们的朋友全栈君。

目录

增强型for循环语法:for(ElementType element:arrayName){};

增强型for循环删除的问题


增强型for循环语法:for(ElementType element:arrayName){};

举个例子:(1)
int[] numArray = { 1, 2, 3, 4, 5, 6 };
for (int i : numArray) {

    System.out.print(i);
}
//结果会是123456 

测试方法 

public static void testFor() {

	int [] array = {1,2,3};
	for(int i : array){
		System.out.println(i);
	}
	List list = new ArrayList();
	list.add(1);
	list.add(2);
	list.add(3);
	for(Object obj : list){
		System.out.println(obj);
	}

	Map<String, String> map = new HashMap<>();
	map.put("1", "1");
	map.put("2", "2");
	map.put("3", "3");
	for (Map.Entry<String, String> stringStringEntry : map.entrySet()) {
		System.out.println(stringStringEntry.getKey() + stringStringEntry.getValue());
	}

}

使用idea查询编译后的class文件

Java基础之增强型for循环

编译后的文件信息为

public static void testFor() {
	int[] array = new int[]{1, 2, 3};
	int[] arr$ = array;
	int len$ = array.length;

	for(int i$ = 0; i$ < len$; ++i$) {
		int i = arr$[i$];
		System.out.println(i);
	}

	List list = new ArrayList();
	list.add(1);
	list.add(2);
	list.add(3);
	Iterator i$ = list.iterator();

	while(i$.hasNext()) {
		Object obj = i$.next();
		System.out.println(obj);
	}

	Map<String, String> map = new HashMap();
	map.put("1", "1");
	map.put("2", "2");
	map.put("3", "3");
	Iterator i$ = map.entrySet().iterator();

	while(i$.hasNext()) {
		Entry<String, String> stringStringEntry = (Entry)i$.next();
		System.out.println((String)stringStringEntry.getKey() + (String)stringStringEntry.getValue());
	}

}

我们发现增强for循环遍历数组时使用的普通for循环,而遍历集合时使用的Iterator迭代器

增强型for循环删除的问题

 测试Java代码

public static void testFor() {

	List list = new ArrayList();
	list.add(1);
	list.add(2);
	list.add(3);
	for(Object obj : list){
		System.out.println(obj);
		list.remove(obj);
	}

}

编译后的class文件信息

public static void testFor() {
	List list = new ArrayList();
	list.add(1);
	list.add(2);
	list.add(3);
	Iterator i$ = list.iterator();

	while(i$.hasNext()) {
		Object obj = i$.next();
		System.out.println(obj);
		list.remove(obj);
	}

}

 执行后

Exception in thread "main" java.util.ConcurrentModificationException
	at java.util.ArrayList$Itr.checkForComodification(ArrayList.java:859)
	at java.util.ArrayList$Itr.next(ArrayList.java:831)
	at com.test.controller.TestMain.testFor(TestMain.java:108)
	at com.test.controller.TestMain.main(TestMain.java:23)

解释说明:

迭代器内部的每次遍历都会记录List内部的modcount当做预期值,然后在每次循环中用预期值与List的成员变量modCount作比较,但是普通list.remove调用的是List的remove,这时modcount++,但是iterator内记录的预期值=并没有变化,所以会报错。

相关源码:

java.util.ArrayList#fastRemove

Java基础之增强型for循环

java.util.ArrayList.Itr#remove

Java基础之增强型for循环

增强型for循环注意事项

  1. 在使用增强型for循环不支持遍历时删除元素
  2. 使用增强型for循环时,对遍历的集合需要做null判断,不然可能引发空指针异常。

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/149848.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • WPF实现界面动态布局

    WPF实现界面动态布局

    2022年1月25日
    42
  • mysql handlersocket_HandlerSocket介绍[通俗易懂]

    mysql handlersocket_HandlerSocket介绍[通俗易懂]HandlerSocket的原理HandlerSocket的应用场景:MySQL自身的局限性,很多站点都采用了MySQL+Memcached的经典架构,甚至一些网站放弃MySQL而采用NoSQL产品,比如Redis/MongoDB等。不可否认,在做一些简单查询(尤其是PK查询)的时候,很多NoSQL产品比MySQL要快很多,而且前台网站上的80%以上查询都是简洁的查询业务。MySQL通过Handl…

    2022年8月24日
    5
  • 前端报502 bad gateway的原因及解决方案

    前端报502 bad gateway的原因及解决方案502BadGateway服务器作为网关或者代理时,为了完成请求访问下一个服务器,但该服务器返回了非法的应答。解决办法是:再刷新一下网页或清理一下电脑的缓冲文件在打开你想打开的网页就好了.一般情况下,这种办法是行得通的,但也不排除你所访问的网页被屏蔽的可能,如果你所访问的网页被屏蔽的话,就不管你怎么刷新也是没用的了。1.什么是502badgateway报错简单来说502是报错…

    2022年9月13日
    2
  • 独立成分分析(ICA)

    独立成分分析(ICA)1.概念独立成分分析是从多元(多维)统计数据中寻找潜在因子或成分的一种方法.ICA与其它的方法重要的区别在于,它寻找满足统计独立和非高斯的成分。这里我们简要介绍ICA的基本概念、应用和估计原理。1.1 多元数据的线性表示统计数据处理及相关领域中的一个重要和需要长期研究的问题就…

    2022年5月17日
    47
  • spinner:获取选中值的三种方法

    spinner:获取选中值的三种方法

    2021年9月30日
    134
  • anp相关_ANP是什么的缩写

    anp相关_ANP是什么的缩写https://www.ctolib.com/docs/sfile/prometheus-book/index.htmlprometheus指南https://e.huawei.com/cn/material/onLineView?MaterialID=c06476e14afe4d45916555318d7b5b5d华为FabricInsight技术白皮书转载于:h…

    2025年6月4日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号