GVKun编程网logo

Collectors.summingInt()与mapToInt()。sum()

23

本文将介绍Collectors.summingInt的详细情况,特别是关于与mapToInt的相关信息。我们将通过案例分析、数据研究等多种方式,帮助您更全面地了解这个主题,同时也将涉及一些关于.fla

本文将介绍Collectors.summingInt的详细情况,特别是关于与mapToInt的相关信息。我们将通过案例分析、数据研究等多种方式,帮助您更全面地了解这个主题,同时也将涉及一些关于.flatMap()或.collect()是否可以平均多个集合、.stream()mapToInt(i-> i)在Java中是什么意思?、67)vector的begin() end() 和 front() back()的区别 rbegin() rend()、Arrays.asList()vs Collections.singletonList()的知识。

本文目录一览:

Collectors.summingInt()与mapToInt()。sum()

Collectors.summingInt()与mapToInt()。sum()

当您想对流中的整数值求和时,有两种主要方法:

ToIntFunction<...> mapFunc = ...int sum = stream().collect(Collectors.summingInt(mapFunc))int sum = stream().mapToInt(mapFunc).sum()

第一个涉及对返回的整数装箱并将其取消装箱,但是第二个步骤涉及额外的步骤。

哪个更有效/更清晰?

答案1

小编典典

您正在看两个否则不同的用例的交集。使用mapToInt(…)可使您IntStream在终端操作之前链接其他操作。相反,Collectors.summingInt(…)可以与其他收集器组合,例如用作收集器中的下游收集groupingBy器。对于这些用例,毫无疑问要使用哪个。

在您的特殊情况下,当您不链接更多操作或不首先与收集器打交道时,这两种方法之间没有根本区别。尽管如此,使用更具可读性的方法还是有道理的。通常,当流上存在预定义的操作时,您就不会使用收集器。collect(Collectors.reducing(…))只要可以使用就不会使用.reduce(…),是吗?

不仅被mapToInt(mapFunc).sum()短路,而且还遵循通常的从左到右的顺序进行概念上的处理,首先转换为an
int,然后将这些ints
相加。我认为这证明了选择这种替代方案是合理的.collect(Collectors.summingInt(mapFunc))

.flatMap()或.collect()是否可以平均多个集合

.flatMap()或.collect()是否可以平均多个集合

比如有收藏[1,2,3,4,5][6,7,8][9,0]。任何避免迭代器循环的方法都可以通过Java 8流API交错这些集合以获得以下结果-
[1,6,9,2,7,0,3,8,4,5]吗?

答案1

小编典典

我不确定Stream API是否有更简单的方法,但是您可以在所有列表的索引上使用流来考虑以下问题:

static <T> List<T> interleave(List<List<T>> lists) {    int maxSize = lists.stream().mapToInt(List::size).max().orElse(0);    return IntStream.range(0, maxSize)                    .boxed()                    .flatMap(i -> lists.stream().filter(l -> i < l.size()).map(l -> l.get(i)))                    .collect(Collectors.toList());}

这将获得给定列表中最大列表的大小。然后,对于每个索引,它使用该列表中每个列表的元素在该索引处形成的流(如果该元素存在的话)进行平面映射。

然后,您可以将其与

public static void main(String[] args) {    List<Integer> list1 = Arrays.asList(1,2,3,4,5);    List<Integer> list2 = Arrays.asList(6,7,8);    List<Integer> list3 = Arrays.asList(9,0);    System.out.println(interleave(Arrays.asList(list1, list2, list3))); // [1, 6, 9, 2, 7, 0, 3, 8, 4, 5]}

使用protonpack库,您可以使用方法interleave来做到这一点:

List<Stream<Integer>> lists = Arrays.asList(list1.stream(), list2.stream(), list3.stream());List<Integer> result = StreamUtils.interleave(Selectors.roundRobin(), lists).collect(Collectors.toList());System.out.println(result);

.stream()mapToInt(i-> i)在Java中是什么意思?

.stream()mapToInt(i-> i)在Java中是什么意思?

通常,mapToInt将流中的每个项目映射到int。它还创建一个IntStream,它具有针对原始类型int

的专用方法。

在这种特定情况下,该方法用于将Integer(包装对象)转换为原始类型的int。使用IntStream可以创建实际的int[]而不是Integer[]

归结为了解原始类型及其包装器之间的区别。尤其是自动装箱。

https://docs.oracle.com/javase/tutorial/java/data/autoboxing.html

67)vector的begin() end() 和 front() back()的区别 rbegin() rend()

67)vector的begin() end() 和 front() back()的区别 rbegin() rend()

1)

··············

 

2)`````````v1.begin() 和v1.end()  是作为迭代器v1的 第一个位置  和 最后一个元素的下一个位置。

`````````````v1.front()   是v1这个动态数组的第一个元素的值  

············ v1.back()是v1的最后一个元素的值。

 

3)

    

 

 4)正向和反向的使用rbegin和begin()

    

 1 #include<iostream>
 2 #include<vector>
 3 
 4 using namespace std;
 5  void hanshu()
 6  {
 7      vector<int> v1;
 8      v1.push_back(2);
 9      v1.push_back(3);
10      v1.push_back(4);
11     //正向遍历
12      for(vector<int>::iterator it=v1.begin();it!=v1.end();it++)
13      {
14         cout<<*it<<endl;
15      }
16      cout<<"开始反向输出这个动态数组了"<<endl;
17      //反向遍历
18      for(vector<int>::reverse_iterator rit=v1.rbegin();rit!=v1.rend();rit++)
19      {
20         cout<<*rit<<endl;
21      }
22 
23 
24  }
25  int main()
26  {
27     hanshu();
28      return 0;
29  }

 

    结果展示:


    

 

Arrays.asList()vs Collections.singletonList()

Arrays.asList()vs Collections.singletonList()

Collections.singletonList(something)不可变的,

Collections.singletonList(something)返回的列表所做的任何更改将导致UnsupportedOperationException 。

Arrays.asList(something)允许Arrays.asList(something) 更改  。

 

此外,由Collections.singletonList(something)返回的List的容量将始终为1,

        而Arrays.asList(something)的容量将为已支持数组的大小。

 /**


* Returns an immutable list containing only the specified object. * The returned list is serializable. * *
@param <T> the class of the objects in the list * @param o the sole object to be stored in the returned list. * @return an immutable list containing only the specified object. * @since 1.3 */ public static <T> List<T> singletonList(T o) { return new SingletonList<>(o); } /** * @serial include */ private static class SingletonList<E> extends AbstractList<E> implements RandomAccess, Serializable { private static final long serialVersionUID = 3093736618740652951L; private final E element; SingletonList(E obj) {element = obj;} public Iterator<E> iterator() { return singletonIterator(element); } public int size() {return 1;} public boolean contains(Object obj) {return eq(obj, element);} public E get(int index) { if (index != 0) throw new IndexOutOfBoundsException("Index: "+index+", Size: 1"); return element; } // Override default methods for Collection @Override public void forEach(Consumer<? super E> action) { action.accept(element); } @Override public boolean removeIf(Predicate<? super E> filter) { throw new UnsupportedOperationException(); } @Override public void replaceAll(UnaryOperator<E> operator) { throw new UnsupportedOperationException(); } @Override public void sort(Comparator<? super E> c) { } @Override public Spliterator<E> spliterator() { return singletonSpliterator(element); } }

 

 

 

 

附录:
package com.ysyc.invoicecertify.util.mockservice;

import java.util.Arrays;
import java.util.List;

/**
 *
 * 本类演示了Arrays类中的asList方法
 * 通过四个段落来演示,体现出了该方法的相关特性.
 *
 * (1) 该方法对于基本数据类型的数组支持并不好,当数组是基本数据类型时不建议使用
 * (2) 当使用asList()方法时,数组就和列表链接在一起了.
 *     当更新其中之一时,另一个将自动获得更新。
 *     注意:仅仅针对对象数组类型,基本数据类型数组不具备该特性
 * (3) asList得到的数组是的没有add和remove方法的
 *
 * 通过查看Arrays类的源码可以知道,asList返回的List是Array中的实现的
 * 内部类,而该类并没有定义add和remove方法.另外,为什么修改其中一个,另一个也自动
 * 获得更新了,因为asList获得List实际引用的就是数组
 */
public class AsListTest {

    public static void main(String[] args) {

        /* 段落一:基本数据类型使用asList中的问题 */

        /* 说明:虽然在JDK1.6中能够将基本数据类型的数组转换成List,但还是有个缺陷 */
        int[] a_int = { 1, 2, 3, 4 };
        /* 预期输出应该是1,2,3,4,但实际上输出的仅仅是一个引用, 这里它把a_int当成了一个元素 */
        List a_int_List = Arrays.asList(a_int);
        foreach(a_int_List);
        /* 为此我们需要这样遍历其中元素 */
        foreachForBase(a_int_List);
        System.out.println("1 END 2 START");
        /* 段落二:对象类型的数组使用asList,是我们预期的 */
        Integer[] a_Integer = new Integer[] { 1, 2, 3, 4 };
        List a_Integer_List = Arrays.asList(a_Integer);
        foreach(a_Integer_List);
        System.out.println("2 END 3 START");

        /* 段落三:当更新数组或者asList之后的List,另一个将自动获得更新 */
        a_Integer_List.set(0, 0);
        foreach(a_Integer_List);
        foreach(a_Integer);
        System.out.println("3 END 4 START");

        a_Integer[0] = 5;
        foreach(a_Integer_List);
        foreach(a_Integer);

        /* 段落四:对基本类型数组,通过asList之后的List修改对应的值后,在运行时会报出异常
         * 但是基本类型数组对应的List是会发生变化的,这是毫无疑问的
         */

         a_int_List.set(0, 0);
          foreach(a_int_List);
          foreach(a_int);

        System.out.println("4 END 5 START");
        a_int[0] = 5;
        foreachForBase(a_int_List);
        foreach(a_int);

    }

    /* 打印方法 */
    private static void foreach(List list) {
        for (Object object : list) {
            System.out.print(object + " ");
        }
        System.out.println();

    }

    private static void foreachForBase(List a_int_List) {
        int[] _a_int = (int[]) a_int_List.get(0);
        foreach(_a_int);
    }

    private static void foreach(int[] a_int) {
        for (int i : a_int) {
            System.out.print(i + " ");
        }
        System.out.println();
    }

    private static void foreach(Integer[] _a_Integer) {
        for (int i : _a_Integer) {
            System.out.print(i + " ");
        }
        System.out.println();
    }
}

console:

Exception in thread "main" java.lang.ArrayStoreException: java.lang.Integer
    at java.util.Arrays$ArrayList.set(Arrays.java:3847)
    at com.ysyc.invoicecertify.util.mockservice.AsListTest.main(AsListTest.java:56)
[I@762efe5d 
1 2 3 4 
1 END 2 START
1 2 3 4 
2 END 3 START
0 2 3 4 
0 2 3 4 
3 END 4 START
5 2 3 4 
5 2 3 4 
Disconnected from the target VM, address: ''127.0.0.1:54490'', transport: ''socket''

Process finished with exit code 1

 

 

关于Collectors.summingInt与mapToInt的介绍已经告一段落,感谢您的耐心阅读,如果想了解更多关于.flatMap()或.collect()是否可以平均多个集合、.stream()mapToInt(i-> i)在Java中是什么意思?、67)vector的begin() end() 和 front() back()的区别 rbegin() rend()、Arrays.asList()vs Collections.singletonList()的相关信息,请在本站寻找。

本文标签: