For循环总结(非原创)

复习JAVA时总结下for循环,是转载两个大佬的。

增强for循环用法

1.首先增强for循环和iterator遍历的效果是一样的,也就说增强for循环的内部也就是调用iteratoer实现的,

但是增强for循环有些缺点,例如不能在增强循环里动态的删除集合内容。不能获取下标等。
2.ArrayList由于使用数组实现,因此下标明确,最好使用普通循环。
3.而对于LinkedList 由于获取一个元素,要从头开始向后找,因此建议使用增强for循环,也就是iterator。
下面的例子可以证明

复制代码
package com.ljq.test;

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;

/**

  • 增强for循环用法
  • @author jiqinlin

*/
public class ForTest {

public static void main(String[] args) {
    
    //List<Integer> list = new ArrayList<Integer>();
    List<Integer> list = new LinkedList<Integer>();
    for (int i = 0; i < 50000; i++) {
        list.add(11);
    }

    int resutl = 0;
    long start = System.currentTimeMillis();
    for (int i = 0; i < list.size(); i++) {
        resutl = list.get(i);
    }
    System.out.println("普通循环使用了"+ (System.currentTimeMillis() - start)+"毫秒");

    
    start = System.currentTimeMillis();
    for (int c2 : list) {
    }
    System.out.println("增强for循环使用了"+ (System.currentTimeMillis() - start)+"毫秒");
}

}
复制代码
使用ArrayList运行结果如下
在这里插入图片描述把ArrayList改为LinkedList,我这里内存溢出了,运行结果如下
在这里插入图片描述
于是list改成50000,运行结果如下
在这里插入图片描述所以在使用的时候适当选择就好了

转载出于:https://www.cnblogs.com/linjiqin/archive/2011/02/10/1950929.html

JAVA 中iterator的两种遍历方式

上面说到增强for和iterator遍历的效果是一样的,所以找到了这篇。

迭代器(Iterator)
迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构。迭代器通常被称为“轻量级”对象,因为创建它的代价小。
  Java中的Iterator功能比较简单,并且只能单向移动:
  (1) 使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。注意:iterator()方法是; font-family:" pingfang="" text-align:="" background-color:="" />   (2) 使用next()获得序列中的下一个元素。
  (3) 使用hasNext()检查序列中是否还有元素。
  (4) 使用remove()将迭代器新返回的元素删除。
  Iterator是Java迭代器最简单的实现,为List设计的ListIterator具有更多的功能,它可以从两个方向遍历List,也可以从List中插入和删除元素。

迭代器应用:
List list = new ArrayList<>();
list.add(1);
list.add(2);
//方法一:
for (Iterator i =list.iterator(); i.hasNext()😉 {
int str = (int) i.next();
System.out.print(str);
}
//方法二:
Iterator it = list.iterator();
while (it.hasNext()) {
int str = (int) it.next();
System.out.print(str);
}

转载于:https://blog.csdn.net/qq_35044419/article/details/79492578

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值