快速理解和使用stream流
數(shù)據(jù)量越大,硬件內(nèi)核數(shù)越多,stream流相比傳統(tǒng)for循環(huán)速度越快。
原因是stream流是可以并行處理的。
如果要使用stream流,可以直接用flatmap把外層嵌套扁平化,只留下自己需要處理的元素
示例:
點擊查看代碼
List<List<Integer>> nestedList = Arrays.asList(
Arrays.asList(1, 2, 3),
Arrays.asList(4, 5, 6),
Arrays.asList(7, 8, 9)
);
List<Integer> resultList = nestedList.stream()
.flatMap(List::stream) // 將外層列表展平
.filter(num -> num % 2 == 0) // sort,forEach,filter,reduce等
.collect(Collectors.toList()); // 將處理后的元素收集到列表中
浙公網(wǎng)安備 33010602011771號