java的这三种for循环有什么区别?

List<User> list = new ArrayList();
1 ---------
for(int i=0;i<list.size();i++){
system.out.println("-------" + list.get(i).getName());
}
2 ---------
for(User u : list){
system.out.println("-------" + u.getName());
}
3------------
List<User> list = new ArrayList<User>();
Iterator i = list.iterator();
while(i.hasNext()){
............
}

第一种是最普通的for循环 这个应该没啥好说的
第二种是第一种for循环的变种也可以说是简写 只能对数组或者是List这样的集合使用 这个是java 1.5新加入的
第三种不是for循环。使用的是迭代器 iterator 像是List这样的集合 一般多是用这种方法
温馨提示:内容为网友见解,仅供参考
第1个回答  2013-08-20
第一种是一般常见的循环,第二种是JDK1.5的新功能,其实也是和第一种一样的只是内部做了一些处理而已,第三中是利用迭代器循环,一般遍历集合。
第2个回答  2013-08-20
2,3没法跟踪循环的次数
1,3没法直接的得到循环的每一个对象
第3个回答  推荐于2018-04-22
第一种for循环遍历ArrayList速度比较快,因为ArrayList是快速随机访问。但是如果想在for循环中使用list.remove方法就会改变list的size,导致循环出现问题。
第二种for循环就可以忽略下标,对每个元素进行处理。不过要使用list的remove方法还是会出现问题。会触发fail-fast机制。
第三种iterator迭代器是由各个list类自己实现的,比如ArrayList有ArrayList自己实现的iterator, Vector有Vector的iterator,因此也会实现iterator内的remove方法。使用iterator就可以使用remove方法而不用担心因为改变表或树的结构而出错了。另iterator遍历LinkedList速度比较快,因为LinkedList顺序查询速度快。本回答被网友采纳
第4个回答  2013-08-20
J2SE 1.5提供了另一种形式的for循环。借助这种形式的for循环,可以用更简单地方式来遍历数组和Collection等类型的对象。本文介绍使用这种循环的具体方式,说明如何自行定义能被这样遍历的类,并解释和这一机制的一些常见问题。
在Java程序中,要“逐一处理”――或者说,“遍历”――某一个数组或Collection中的元素的时候,一般会使用一个for循环来实现(当然,用其它种类的循环也不是不可以,只是不知道是因为for这个词的长度比较短,还是因为for这个词的含义和这种操作比较配,在这种时候for循环比其它循环常用得多)。
对于遍历数组,这个循环一般是采取这样的写法:
清单1:遍历数组的传统方式

复制代码代码如下:

/* 建立一个数组 */
int[] integers = {1, 2, 3, 4};
/* 开始遍历 */
for (int j = 0; j < integers.length; j++) {
int i = integers[j];
System.out.println(i);
}

而对于遍历Collection对象,这个循环则通常是采用这样的形式:

清单2:遍历Collection对象的传统方式

复制代码代码如下:

/* 建立一个Collection */
String[] strings = {"A", "B", "C", "D"};
Collection stringList = java.util.Arrays.asList(strings);
/* 开始遍历 */
for (Iterator itr = stringList.iterator(); itr.hasNext();) {
Object str = itr.next();
System.out.println(str);
}

而在Java语言的最新版本――J2SE 1.5中,引入了另一种形式的for循环。借助这种形式的for循环,现在可以用一种更简单地方式来进行遍历的工作。

1、 第二种for循环
不严格的说,Java的第二种for循环基本是这样的格式:
for (循环变量类型 循环变量名称 : 要被遍历的对象) 循环体
借助这种语法,遍历一个数组的操作就可以采取这样的写法:
清单3:遍历数组的简单方式

复制代码代码如下:

/* 建立一个数组 */
int[] integers = {1, 2, 3, 4};

/* 开始遍历 */
for (int i : integers) {
System.out.println(i); /* 依次输出“1”、“2”、“3”、“4” */
}

这里所用的for循环,会在编译期间被看成是这样的形式:

清单4:遍历数组的简单方式的等价代码

复制代码代码如下:

/* 建立一个数组 */
int[] integers = {1, 2, 3, 4};

/* 开始遍历 */
for (int 变量名甲 = 0; 变量名甲 < integers.length; 变量名甲++) {
System.out.println(integers[变量名甲]); /* 依次输出“1”、“2”、“3”、“4” */
}

这里的“变量名甲”是一个由编译器自动生成的不会造成混乱的名字。

而遍历一个Collection的操作也就可以采用这样的写法:
清单5:遍历Collection的简单方式

复制代码代码如下:

/* 建立一个Collection */
String[] strings = {"A", "B", "C", "D"};
Collection list = java.util.Arrays.asList(strings);

/* 开始遍历 */
for (Object str : list) {
System.out.println(str); /* 依次输出“A”、“B”、“C”、“D” */
}

这里所用的for循环,则会在编译期间被看成是这样的形式:

清单6:遍历Collection的简单方式的等价代码

复制代码代码如下:

/* 建立一个Collection */
String[] strings = {"A", "B", "C", "D"};
Collection stringList = java.util.Arrays.asList(strings);

/* 开始遍历 */
for (Iterator 变量名乙 = list.iterator(); 变量名乙.hasNext();) {
Object str = 变量名乙.next();
System.out.println(str); /* 依次输出“A”、“B”、“C”、“D” */
}

这里的“变量名乙”也是一个由编译器自动生成的不会造成混乱的名字。
因为在编译期间,J2SE 1.5的编译器会把这种形式的for循环,看成是对应的传统形式,所以不必担心出现性能方面的问题。
不用“foreach”和“in”的原因
Java采用“for”(而不是意义更明确的“foreach”)来引导这种一般被叫做“for-each循环”的循环,并使用“:”(而不是意义更明确的“in”)来分割循环变量名称和要被遍历的对象。这样作的主要原因,是为了避免因为引入新的关键字,造成兼容性方面的问题――在Java语言中,不允许把关键字当作变量名来使用,虽然使用“foreach”这名字的情况并不是非常多,但是“in”却是一个经常用来表示输入流的名字(例如java.lang.System类里,就有一个名字叫做“in”的static属性,表示“标准输入流”)。
的确可以通过巧妙的设计语法,让关键字只在特定的上下文中有特殊的含义,来允许它们也作为普通的标识符来使用。不过这种会使语法变复杂的策略,并没有得到广泛的采用。
“for-each循环”的悠久历史
“for-each循环”并不是一个最近才出现的控制结构。在1979正式发布的Bourne shell(第一个成熟的UNIX命令解释器)里就已经包含了这种控制结构(循环用“for”和“in”来引导,循环体则用“do”和“done”来标识)。
2、防止在循环体里修改循环变量
在默认情况下,编译器是允许在第二种for循环的循环体里,对循环变量重新赋值的。不过,因为这种做法对循环体外面的情况丝毫没有影响,又容易造成理解代码时的困难,所以一般并不推荐使用。
Java提供了一种机制,可以在编译期间就把这样的操作封杀。具体的方法,是在循环变量类型前面加上一个“final”修饰符。这样一来,在循环体里对循环变量进行赋值,就会导致一个编译错误。借助这一机制,就可以有效的杜绝有意或无意的进行“在循环体里修改循环变量”的操作了。
清单7:禁止重新赋值

复制代码代码如下:

int[] integers = {1, 2, 3, 4};
for (final int i : integers) {
i = i / 2; /* 编译时出错 */
}

注意,这只是禁止了对循环变量进行重新赋值。给循环变量的属性赋值,或者调用能让循环变量的内容变化的方法,是不被禁止的。

清单8:允许修改状态

复制代码代码如下:

Random[] randoms = new Random[]{new Random(1), new Random(2), new Random(3)};
for (final Random r : randoms) {
r.setSeed(4); /* 将所有Random对象设成使用相同的种子 */
System.out.println(r.nextLong()); /* 种子相同,第一个结果也相同 */
}

3. 类型相容问题

为了保证循环变量能在每次循环开始的时候,都被安全的赋值,J2SE 1.5对循环变量的类型有一定的限制。这些限制之下,循环变量的类型可以有这样一些选择:
循环变量的类型可以和要被遍历的对象中的元素的类型相同。例如,用int型的循环变量来遍历一个int[]型的数组,用Object型的循环变量来遍历一个Collection等。
清单9:使用和要被遍历的数组中的元素相同类型的循环变量

复制代码代码如下:

int[] integers = {1, 2, 3, 4};
for (int i : integers) {
System.out.println(i); /* 依次输出“1”、“2”、“3”、“4” */
}

清单10:使用和要被遍历的Collection中的元素相同类型的循环变量
Collection< String> strings = new ArrayList< String>();
strings.add("A");
strings.add("B");
strings.add("C");
strings.add("D");
for (String str : integers) {
System.out.println(str); /* 依次输出“A”、“B”、“C”、“D” */
}

循环变量的类型可以是要被遍历的对象中的元素的上级类型。例如,用int型的循环变量来遍历一个byte[]型的数组,用Object型的循环变量来遍历一个Collection< String>(全部元素都是String的Collection)等。
清单11:使用要被遍历的对象中的元素的上级类型的循环变量
String[] strings = {"A", "B", "C", "D"};
Collection< String> list = java.util.Arrays.asList(strings);
for (Object str : list) {
System.out.println(str);/* 依次输出“A”、“B”、“C”、“D” */
}
循环变量的类型可以和要被遍历的对象中的元素的类型之间存在能自动转换的关系。J2SE 1.5中包含了“Autoboxing/Auto-Unboxing”的机制,允许编译器在必要的时候,自动在基本类型和它们的包裹类(Wrapper Classes)之间进行转换。因此,用Integer型的循环变量来遍历一个int[]型的数组,或者用byte型的循环变量来遍历一个Collection< Byte>,也是可行的。
清单12:使用能和要被遍历的对象中的元素的类型自动转换的类型的循环变量
int[] integers = {1, 2, 3, 4};
for (Integer i : integers) {
System.out.println(i); /* 依次输出“1”、“2”、“3”、“4” */
}
注意,这里说的“元素的类型”,是由要被遍历的对象的决定的――如果它是一个Object[]型的数组,那么元素的类型就是Object,即使里面装的都是String对象也是如此。
可以限定元素类型的Collection
截至到J2SE 1.4为止,始终无法在Java程序里限定Collection中所能保存的对象的类型――它们全部被看成是最一般的Object对象。一直到J2SE 1.5中,引入了“泛型(Generics)”机制之后,这个问题才得到了解决。现在可以用Collection< T>来表示全部元素类型都是T的Collection。

java的这三种for循环有什么区别?
第一种是最普通的for循环 这个应该没啥好说的 第二种是第一种for循环的变种也可以说是简写 只能对数组或者是List这样的集合使用 这个是java 1.5新加入的 第三种不是for循环。使用的是迭代器 iterator 像是List这样的集合 一般多是用这种方法 ...

Java的for循环、增强for循环、lambda表达式中的forEach三种方式优缺点...
2. for循环的劣势在于,它仅适用于有序集合和数组,因为需要通过下标来获取元素。对于无序集合如Set或映射集合如Map,for循环无法直接遍历。3. 增强for循环(也称为for-each循环)的优点在于,它简化了循环语法,无需编写下标变量即可直接赋值给循环变量。这种循环可以用于所有集合类型和数组。4. 增强for...

Java的for循环、增强for循环、lambda表达式中的forEach 三种方式优缺 ...
简单的来说其实三种并没有什么太大的区别,一般情况下的性能也差不多。for循环:优点:可以直接获取下标,能更精确的定位。下标变量属于循环内变量,循环结束会自动回收。下标变量的步长可以自定,比较灵活。缺点:需要根据下标才会获取循环内容。只能循环有序集合和数组,如Set和Map就无法遍历。增强for:优...

java for循环用法
java中有三种类型的for循环。1、简单for循环2、for-each或增强型for循环3、标记for循环。Java简单For循环:简单的for循环与C\/C++相同。我们可以初始化变量,检查条件和增加\/减少变量的值。语法为:for(initialization;condition;incr\/decr){ \/\/code to be executed } Java for-each循环:for-each循环用...

java for循环中break,continue区别是什么?
在for循环中break与continue的区别如下:break用于完全结束一个循环,跳出循环体执行循环后面的语句;而continue是跳过当次循环中剩下的语句,执行下一次循环。简单点说就是break完全结束循环,continue终止本次循环。下面举个小例子:var str = "hello";for (var item of str){ if(item ==="l"){ ...

java里面的for循环的格式: for(String s : arr)是什么意思,能否详细...
for的循环语句for(String s : args)这个格式是foreach的形式,表示取出数组args[]中的每一个元素,就是循环一次就依次取出一个元素赋值给s,知道取完为止java中的foreach也是用for表示具体语法分两种:第一种-数组for(type var : arr) {\/\/循环体}示例(这里以List为例):List<String> list = ...

JAVA中for(x=1,x<=3,x++)for里面的这3项分别是什么意思
第一项x=1表示的是这个循环开始时,x的初始值是1 第二项x<=3表示每次进行循环的时候,要先测试一下这个条件,如果满足则执行,如果不满足则结束这个循环 第三项x++表示每次循环后将x的值加1 等价于:int x = 1;while(x<=3){ ...x++;} 加2的话x+=2就行了或者x=x+2都是一样的哈。

java中、for循环里面的三个表达式到底代表什么啊、什么循环变量初始值...
1、java中,for循环的格式一般如下几种 for(语句1;条件;语句2){\/\/语句1,2,就是正常的语句,条件语句是需要循环执行下去必须符合的条件,\/\/条件句可以为空,不写就等同于true\/\/{}内就是等待执行的语句,也叫循环体}\/**例如:**\/\/**1、**\/for(int i=0;i<n;i++){\/\/语句1定义了一...

java中有什么循环吗?
for 循环。Java 增强 for 循环语法格式如下:for(声明语句 : 表达式){ \/\/代码句子} 声明语句:声明新的局部变量,该变量的类型必须和数组元素的类型匹配。其作用域限在循环语句块,其值与此时数组元素的值相等。表达式:表达式是要访问的数组名,或者是返回值为数组的方法。

用java实现三种方法循环输出九九乘法表:
for循环的结构:for(表达式 1;表达式 2;表达式 3) { 循环体 } 表达式 1:一般为赋值表达式;表达式 2:一般为关系表达式或逻辑表达式;表达式 3:一般为赋值表达式或自增、自减表达式,用以修改循环变量的值。while循环的结构: while(表达式) 循环体 1、while 是C语言中的关键字;2、圆...

相似回答