一、对ArrayList与LinkedList分别使用10w次不同的方式进行遍历,试了三次,结果如下
arrayList:for:12
arrayList:for-earch:11
arrayList:forEach:167
arrayList:parallelStream().forEach:18
arrayList:stream().collect:14
linkedList:for:13081
linkedList:for-earch:10
linkedList:forEach:7
linkedList:parallelStream().forEach:8
linkedList:stream().collect:7
arrayList:for:14
arrayList:for-earch:24
arrayList:forEach:143
arrayList:parallelStream().forEach:16
arrayList:stream().collect:16
linkedList:for:11562
linkedList:for-earch:3
linkedList:forEach:6
linkedList:parallelStream().forEach:8
linkedList:stream().collect:6
arrayList:for:13
arrayList:for-earch:11
arrayList:forEach:120
arrayList:parallelStream().forEach:25
arrayList:stream().collect:18
linkedList:for:9482
linkedList:for-earch:6
linkedList:forEach:7
linkedList:parallelStream().forEach:8
linkedList:stream().collect:6
二、根据结果总结
使用ArrayList的时候,使用list.forEach()这个性能最差,差距性能比其他方式差10倍
使用LinkedList的时候,使用for(int i=0;i<size;i++)这种方式性能最差,比其他方式差100倍
三、测试代码
public class ForTestMain { public static void main(String[] args) { List<Object> arrayList=new ArrayList<>(); List<Object> linkedList=new LinkedList<>(); for(int i=0;i<100000;i++){ arrayList.add(i); linkedList.add(i); } compare("arrayList",arrayList); compare("linkedList",linkedList); } public static void compare(String flag,List<Object> dataList){ int size=dataList.size(); long startTime=System.currentTimeMillis(); for(int i=0;i<size;i++){ dataList.get(i); } long finish=System.currentTimeMillis(); System.out.println(flag+":for:"+(finish-startTime)); startTime=System.currentTimeMillis(); for(Object data:dataList){ } finish=System.currentTimeMillis(); System.out.println(flag+":for-earch:"+(finish-startTime)); startTime=System.currentTimeMillis(); dataList.forEach(s->{}); finish=System.currentTimeMillis(); System.out.println(flag+":forEach:"+(finish-startTime)); startTime=System.currentTimeMillis(); dataList.parallelStream().forEach(s->{}); finish=System.currentTimeMillis(); System.out.println(flag+":parallelStream().forEach:"+(finish-startTime)); startTime=System.currentTimeMillis(); dataList.stream().collect(Collectors.toList()); finish=System.currentTimeMillis(); System.out.println(flag+":stream().collect:"+(finish-startTime)); } }