package org.ssh.coll;
import java.util.AbstractCollection;
import java.util.AbstractList;
import java.util.AbstractMap;
import java.util.AbstractQueue;
import java.util.AbstractSequentialList;
import java.util.AbstractSet;
import java.util.ArrayDeque;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.BitSet;
import java.util.Calendar;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.ConcurrentModificationException;
import java.util.Currency;
//import java.util.CurrencyData;
import java.util.Date;
import java.util.Deque;
import java.util.Dictionary;
import java.util.DuplicateFormatFlagsException;
import java.util.EmptyStackException;
import java.util.Enumeration;
import java.util.EnumMap;
import java.util.EnumSet;
import java.util.EventListener;
import java.util.EventListenerProxy;
import java.util.EventObject;
import java.util.FormatFlagsConversionMismatchException;
import java.util.Formattable;
import java.util.FormattableFlags;
import java.util.Formatter;
import java.util.FormatterClosedException;
import java.util.GregorianCalendar;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Hashtable;
import java.util.IdentityHashMap;
import java.util.IllegalFormatCodePointException;
import java.util.IllegalFormatConversionException;
import java.util.IllegalFormatException;
import java.util.IllegalFormatFlagsException;
import java.util.IllegalFormatPrecisionException;
import java.util.IllegalFormatWidthException;
import java.util.InputMismatchException;
import java.util.InvalidPropertiesFormatException;
import java.util.Iterator;
//import java.util.JapaneseImperialCalendar;
//import java.util.JumboEnumSet;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.ListIterator;
import java.util.ListResourceBundle;
import java.util.Locale;
//import java.util.LocaleISOData;
import java.util.Map;
import java.util.MissingFormatArgumentException;
import java.util.MissingFormatWidthException;
import java.util.MissingResourceException;
import java.util.NavigableMap;
import java.util.NavigableSet;
import java.util.NoSuchElementException;
import java.util.Observable;
import java.util.Observer;
import java.util.PriorityQueue;
import java.util.Properties;
import java.util.PropertyPermission;
//import java.util.PropertyPermissionCollection;
import java.util.PropertyResourceBundle;
import java.util.Queue;
import java.util.Random;
import java.util.RandomAccess;
//import java.util.RandomAccessSubList;
//import java.util.RegularEnumSet;
import java.util.ResourceBundle;
import java.util.Scanner;
import java.util.ServiceConfigurationError;
import java.util.ServiceLoader;
import java.util.Set;
import java.util.SimpleTimeZone;
import java.util.SortedMap;
import java.util.SortedSet;
import java.util.Stack;
import java.util.StringTokenizer;
//import java.util.SubList;
//import java.util.TaskQueue;
import java.util.Timer;
import java.util.TimerTask;
//import java.util.TimerThread;
import java.util.TimeZone;
import java.util.TooManyListenersException;
import java.util.TreeMap;
import java.util.TreeSet;
import java.util.UnknownFormatConversionException;
import java.util.UnknownFormatFlagsException;
import java.util.UUID;
import java.util.Vector;
import java.util.WeakHashMap;
//import java.util.XMLUtils;
/**
* 测试大集合的遍历速度
*
* root Collection and Map
*
* 常用集合 list map set
*
* @author dgt
*
*/
public class LargeCollTest
{
public static void main(String[] args)
{
List<String> list = new ArrayList<String>();
for (int i = 1; i <= 2000000; i++)
{
list.add(String.valueOf(i));
}
// 方法1
Iterator<String> it1 = list.iterator();
long t1 = System.currentTimeMillis();
while (it1.hasNext())
{
it1.next();
}
long t2 = System.currentTimeMillis();
System.out.println("list 循环1 的时间差 = "+ (t2-t1));
// 方法2 怪异!
long t3 = System.currentTimeMillis();
for (Iterator<String> it2 = list.iterator(); it2.hasNext();)
{
it2.next();
}
long t4 = System.currentTimeMillis();
System.out.println("list 循环2 的时间差 = "+ (t4-t3));
// 方法3
long t5 = System.currentTimeMillis();
for (String tmp : list)
{
String s = tmp;
}
long t6 = System.currentTimeMillis();
System.out.println("list 循环3 的时间差 = "+ (t6-t5));
// 方法4
long t7 = System.currentTimeMillis();
for (int i = 0; i < list.size(); i++)
{
list.get(i);
}
long t8 = System.currentTimeMillis();
System.out.println("list 循环4 的时间差 = "+ (t8-t7));
}
}
各种测试时间比较
添加一百万的时候状态:
list 循环1 的时间差 = 31
list 循环2 的时间差 = 47
list 循环3 的时间差 = 31
list 循环4 的时间差 = 16
list 循环1 的时间差 = 32
list 循环2 的时间差 = 46
list 循环3 的时间差 = 32
list 循环4 的时间差 = 15
list 循环1 的时间差 = 47
list 循环2 的时间差 = 31
list 循环3 的时间差 = 31
list 循环4 的时间差 = 16
list 循环1 平均的时间差 = 36.6
list 循环2 平均的时间差 = 41.3
list 循环3 平均的时间差 = 31.3
list 循环4 平均的时间差 = 15.6
===========================
添加二百万的时候状态:
list 循环1 的时间差 = 93
list 循环2 的时间差 = 78
list 循环3 的时间差 = 78
list 循环4 的时间差 = 32
list 循环1 的时间差 = 62
list 循环2 的时间差 = 78
list 循环3 的时间差 = 63
list 循环4 的时间差 = 31
list 循环1 的时间差 = 78
list 循环2 的时间差 = 63
list 循环3 的时间差 = 78
list 循环4 的时间差 = 31
list 循环1 平均的时间差 = 77.6
list 循环2 平均的时间差 = 73
list 循环3 平均的时间差 = 73
list 循环4 平均的时间差 = 31.3
如有不妥,敬请补充。