java数组遍历效率_java中数组多种遍历求和的效率分析

java中数组多种遍历求和的效率分析

int型数组的遍历求和效率分析

转换成流的形式,再求和。IntStream.of(a).sum();

另一种转换流求和的方式,Arrays.stream(a).sum();

普通for loop 求和:for i

增强for loop 求和:for-each

测试方法使用的是 System.nanoTime() 求出求和段的运行时间,单位为纳秒(10^-9 s)

测试代码如下:

class Solution {

public static void main(String[] args) {

int[] a = new int[100];

for (int i = 0; i < 100; i++) {

a[i] = i + 1;

}

long l1, l2;

int sum1, sum2, sum3 = 0, sum4 = 0;

l1 = System.nanoTime();

sum1 = IntStream.of(a).sum();

l2 = System.nanoTime();

System.out.print("IntStream.of(a).sum(): ");

System.out.println(sum1);

System.out.println(l2 - l1);

l1 = System.nanoTime();

sum2 = Arrays.stream(a).sum();

l2 = System.nanoTime();

System.out.print("Arrays.stream(a).sum(): ");

System.out.println(sum2);

System.out.println(l2 - l1);

l1 = System.nanoTime();

for (int i = 0; i < a.length; i++) {

sum3 += a[i];

}

l2 = System.nanoTime();

System.out.print("for loop: ");

System.out.println(sum3);

System.out.println(l2 - l1);

l1 = System.nanoTime();

for (int i : a) {

sum4 += i;

}

l2 = System.nanoTime();

System.out.print("iterator loop: ");

System.out.println(sum4);

System.out.println(l2 - l1);

}

}

IntStream.of(a).sum(): 5050

24215600

Arrays.stream(a).sum(): 5050

184000

for loop: 5050

1600

iterator loop: 5050

1800

求和结果都是正确的。所以根据最后求和速度进行排序,效率从低到高:

IntStream.of(A).sum() < Arrays.stream(A).sum() < iterator loop < for loop

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值