网上结论:

如果是链表结构的集合,如LinkedList,则使用迭代器遍历,速度会更快(顺序获取)。

如果是数组结构的,如ArrayList,则使用for循环会更快(随机获取)

测试代码:

package com.ckhuang.maven.confused;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List; /**
* 验证遍历不同类型集合(基于数组的 and 基于链表的)<br/>
* FOR 跟 迭代器Iterator 的性能区别
*
* @author ck.huang
*
*/
public class ShowDifForAndIterator { /**
* @param args
*/
public static void main(String[] args) {
// 集合大小
int cSize = 80000; validateArray(cSize);
System.out.println("==========================================");
validateLinked(cSize);
} private static void validateLinked(int cSize) {
long insertStart = System.currentTimeMillis();
LinkedList<Bussiness> list = createLinkedList(cSize);
long insertEnd = System.currentTimeMillis();
System.out.println("往 LinkedList 插入 " + cSize + "个对象,耗时:" + (insertEnd - insertStart)); doCompare(list, "LinkedList");
} private static void validateArray(int cSize) {
long insertStart = System.currentTimeMillis();
ArrayList<Bussiness> list = createArrayList(cSize);
long insertEnd = System.currentTimeMillis();
System.out.println("往 ArrayList 插入 " + cSize + "个对象,耗时:" + (insertEnd - insertStart)); doCompare(list, "ArrayList");
} private static void doCompare(List<Bussiness> list, String type) {
long forStart = System.currentTimeMillis();
doFor(list);
long forEnd = System.currentTimeMillis();
System.out.println(type + "(" + list.size() + ") 使用FOR 遍历,耗时:" + (forEnd - forStart)); long linkedStart = System.currentTimeMillis();
doIterator(list);
long linkedEnd = System.currentTimeMillis();
System.out.println(type + "(" + list.size() + ") 使用Iterator遍历,耗时:" + (linkedEnd - linkedStart)); } private static void doFor(List<Bussiness> list) {
for (int i = 0; i < list.size(); i++) {
Bussiness buss = list.get(i);
buss.doSomething();
}
} private static void doIterator(List<Bussiness> list) {
Iterator<Bussiness> iterator = list.iterator();
while (iterator.hasNext()) {
Bussiness buss = iterator.next();
buss.doSomething();
}
} public static LinkedList<Bussiness> createLinkedList(int size) {
LinkedList<Bussiness> list = new LinkedList<Bussiness>();
for (int i = 0; i < size; i++) {
list.add(new Bussiness());
}
return list;
} public static ArrayList<Bussiness> createArrayList(int size) {
ArrayList<Bussiness> list = new ArrayList<Bussiness>();
for (int i = 0; i < size; i++) {
list.add(new Bussiness());
}
return list;
} } class Bussiness {
public void doSomething() {
// do nothing..
}
}

结果:

往 ArrayList 插入 80000个对象,耗时:15

ArrayList(80000) 使用FOR 遍历,耗时:0

ArrayList(80000) 使用Iterator遍历,耗时:16

==========================================

往 LinkedList 插入 80000个对象,耗时:0

LinkedList(80000) 使用FOR 遍历,耗时:14570

LinkedList(80000) 使用Iterator遍历,耗时:16

后记:

1. 相对ArrayList,LinekedList的插入速度更快。

2. ArrayList使用FOR循环遍历,速度更快。

3. LinekedList使用Iterator遍历,速度更快。

遍历ArrayList与LinkedList,使用FOR与迭代器的区别的更多相关文章

  1. ArrayList、LinkedList、Vector、CopyOnWriteArrayList的区别和源码分析

    1. ArrayList ArrayList 是一个数组队列,相当于动态数组.与Java中的数组相比,它的容量能动态增长.它继承于AbstractList,实现了List, RandomAccess, ...

  2. ArrayList、LinkedList、HashMap的遍历及遍历过程中增、删元素

    ArrayList.LinkedList.HashMap是Java中常用到的几种集合类型,遍历它们是时常遇到的情况.当然还有一些变态的时候,那就是在遍历的过程中动态增加或者删除其中的元素. 下面的例子 ...

  3. Java ArrayList和LinkedList

    目录 集合的概念 集合体系结构 常用list集合 list集合的特点 ArrayList LinkedList 创建对象 常用方法 遍历 ArrayList和LinkedList的区别 集合的概念 ​ ...

  4. ArrayList和LinkedList、Vector的优缺点?

    一般在面试中可能会被问到ArrayList.LinkedList.Vector三者相关的区别! 一般来说我想大概都会回答如下的这些: ArrayList底层是数组结构,查询快,增删慢,线程不安全,效率 ...

  5. Java中ArrayList和LinkedList差别

    一般大家都知道ArrayList和LinkedList的大致差别: 1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构.  2.对于随机訪问get和set.A ...

  6. JAVA集合一:ArrayList和LinkedList

    JAVA集合一:ArrayList和LinkedList 参考链接: HOW2J.CN 前言 这几篇博客重点记录JAVA的几个重要的集合框架:ArrayList.LinkedList.HashMap. ...

  7. 迭代器遍历列表 构造方法 constructor ArrayList Vector LinkedList Array List 时间复杂度

    package priceton; import java.io.IOException; import java.util.concurrent.CyclicBarrier; import java ...

  8. ArrayList和LinkedList的几种循环遍历方式及性能对比分析(转)

    主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论. 通过本文你可以 ...

  9. ArrayList和LinkedList的几种循环遍历方式及性能对比分析

    最新最准确内容建议直接访问原文:ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性 ...

随机推荐

  1. 不管肉鸡,还是代理,CC识别就封杀!

    这几天的心得,汇成代码. PYTHON版,我编的. #!/usr/bin/env python # -*- coding: utf-8 -*- import os,sys,time import co ...

  2. 使用Keil软件编写汇编源程序应注意事项

    1)一定要使用微软的txt文本编辑器,否则键入逗号时编译通不过.应该是这个样('),不该是这个样(,). 2) 用数字做标号时,前面一定要加一个英文字母,否则编译通不过. 3) 有时编译通过的.asm ...

  3. 【Latex】怎么写中文?

    最近总有这么几种情况:一.作业很简单,想用Latex敲,但是英语不过硬,用中文吧配中文环境就要配置半天.二.越来越多的朋友问我怎么搞中文输入,我也确实没啥帮助人家的好办法,所以只好自己研究研究怎么配置 ...

  4. DBA避坑宝典:Oracle运维中的那些事儿

    对于Oracle运维中的那些事儿,我的最终目的:不是比谁更惨,而是能够从中吸取经验和教训. 从我的理解来看,我会从下面的几个方面来进行说明DBA运维中的一些事儿. 每个部分都是非常关键的,缺一不可,而 ...

  5. 关于bootstrap--表格(tr的各种样式)

    只需要<tr class="active">就可以用active样式. 特别提示:除了”.active”之外,其他四个类名和”.table-hover”配合使用时,Bo ...

  6. [WPF] 将普通的Library工程,改造成WPF Custom Control 的Library

    1. 添加References PresentationCore PresentationFramework System.Xaml WindowsBase2. 修改AssemblyInfo.xsus ...

  7. python高级编程:有用的设计模式3

    # -*- coding: utf-8 -*-__author__ = 'Administrator'#python高级编程:有用的设计模式#访问者:有助于将算法从数据结构中分离出来"&qu ...

  8. pyqt学习之列表管理器(网友提供)

    # -*- coding: utf-8 -*- __author__ = 'Administrator' import sys from PyQt4.QtCore import * from PyQt ...

  9. java遍历Hashmap/Hashtable的几种方法

    一>java遍历Hashtabe: import java.util.Hashtable; import java.util.Set; public class HashTableTest { ...

  10. single-row function和muti-row function

    1.single-row function 指一行数据输入,返回一个值的函数. 常见的有 字符函数(如:substr) 日期函数(如:months_between) 数字函数(如:MOD) 转换函数( ...