Java 8 mapToInt(mapToInt(e – > e))如何提高性能?

我正在阅读“ Java 8 Lambdas”这本书,在某些时候,作者说:“尽可能使用原始的专业功能一个好主意,因为
性能优势“.

在这里指的是mapToInt,mapToLong等

事实上,我不知道演员表现来自于诚实.

我们来看一个例子:

// Consider this a very very long list,with a lot of elements
    List<Integer> list = Arrays.asList(1,2,3,4);

    //sum it,flavour 1
    int sum1 = list.stream().reduce(0,(acc,e) -> acc + e).intValue();

    //sum it,flavour 2
    int sum2 = list.stream().mapToInt(e -> e).sum();

    System.out.println(sum1 + " " + sum2);

因此,在第一种情况下,我使用reduce来计算值,所以BinaryOperator函数将一直收到int(acc)和Integer(集合的当前元素),然后将对Integer进行解包int(acc)

在第二种情况下,我使用mapToInt,它将每个Integer解包成一个int,然后对它进行求和.

我的问题是,第二种方法有什么好处吗?
还有什么地图到int,当我可以使用地图?

那么是的,这只是糖语法,还是具有一定的性能优势?如果是,请提供一些信息

问候,

解决方法

有更多的拳击进行水平
int sum1 = list.stream().reduce(0,e) -> acc + e).intValue();

因为还原函数是二进制运算符<整数> – 它通过两个整数值,取消收件箱,添加它们,然后重新包装结果. mapToInt版本从列表中取消打包Integer元素一次,然后使用原始int值作为IntStream.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...