java基础之List遍历速度

一、对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));
    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风中情

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值