本文将介绍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()
- .flatMap()或.collect()是否可以平均多个集合
- .stream()mapToInt(i-> i)在Java中是什么意思?
- 67)vector的begin() end() 和 front() back()的区别 rbegin() rend()
- Arrays.asList()vs Collections.singletonList()
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()
短路,而且还遵循通常的从左到右的顺序进行概念上的处理,首先转换为anint
,然后将这些int
s
相加。我认为这证明了选择这种替代方案是合理的.collect(Collectors.summingInt(mapFunc))
。
.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中是什么意思?
通常,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()
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()
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()的相关信息,请在本站寻找。
本文标签: