java 流常用接口_java 8新特性5--使用集合流式API

PS:向公众号发送关键字可以搜索文章哦!

使用集合的流式API

直接上代码了,常用api都有了,要点都在注释中

苹果类:

packagejava8.stream;/***@authorqiang.xie*@date2017/5/4*/public classApple {

private intweight;privateString color;privateString catalog;publicApple(intweight,String color,String catalog) {

this.weight= weight;this.color= color;this.catalog= catalog;}

public intgetWeight() {

returnweight;}

public voidsetWeight(intweight) {

this.weight= weight;}

publicString getColor() {

returncolor;}

public voidsetColor(String color) {

this.color= color;}

publicString getCatalog() {

returncatalog;}

public voidsetCatalog(String catalog) {

this.catalog= catalog;}

//以颜色和品类决定两个苹果是否一样@Overridepublic booleanequals(Object o) {

if(this== o) return true;if(o == null|| getClass() != o.getClass()) return false;Apple apple = (Apple) o;if(color!= null? !color.equals(apple.color) : apple.color!= null) return false;returncatalog!= null? catalog.equals(apple.catalog) : apple.catalog== null;}

@Overridepublic inthashCode() {

intresult = color!= null? color.hashCode() : 0;result = 31* result + (catalog!= null? catalog.hashCode() : 0);returnresult;}

@OverridepublicString toString() {

return"重量:"+weight+",颜色:"+color+",品类:"+catalog;}

}

测试类:

packagejava8.stream;importjava.util.ArrayList;importjava.util.Arrays;importjava.util.List;importjava.util.stream.Collectors;/***@authorqiang.xie*@date2017/5/4*/public classStreamApiTest {

public static voidmain(String[] arg) {

List apples = newArrayList<>();apples.add(newApple(1,"red","红富士"));apples.add(newApple(3,"red","红富士"));apples.add(newApple(2,"red","山东苹果"));apples.add(newApple(4,"red","山东苹果"));apples.add(newApple(5,"green","红富士"));apples.add(newApple(7,"green","红富士"));apples.add(newApple(6,"green","山东苹果"));apples.add(newApple(8,"green","山东苹果"));//filter 筛选符合条件的数据并返回一个新的流//collect将流中的数据收集List reds=apples.stream().filter(apple -> apple.getColor().equals("red")).collect(Collectors.toList());System.out.println(reds);//distinct 去重(根据对象的equals和hashcode方法比较两个对象是否是同一个对象)List distincts=apples.stream().distinct().collect(Collectors.toList());System.out.println(distincts);//限制结果集的大小List limits=apples.stream().limit(1).collect(Collectors.toList());System.out.println(limits);//跳过元素个数,结合limit可以实现类似数据库的分页List skips=apples.stream().skip(6).collect(Collectors.toList());System.out.println(skips);//映射,将流中的每个元素变成映射成另一个元素,注意,所有流操作都是在一个新的流中处理,原始流中的数据都不会改变List colors=apples.stream().map(apple -> apple.getColor()).collect(Collectors.toList());//从apple中提取颜色System.out.println(colors);//将流中的元素扁平化//anyMatch是否存在满足条件的苹果System.out.println(apples.stream().anyMatch(apple -> apple.getWeight()==2));//allMatch所有元素是否都满足条件System.out.println(apples.stream().allMatch(apple -> apple.getWeight()==2));//noneMatch是否所有元素都不满足条件System.out.println(apples.stream().noneMatch(apple -> apple.getWeight()==2));//findAny从流中查找任意一个元素,通常结合filter一起用System.out.println(apples.stream().findAny().get());//findFirst从流中查找第一个元素,通常结合filter一起用System.out.println(apples.stream().filter(apple -> apple.getWeight()>1).findFirst().get());//count统计流中的元素个数System.out.println("count:"+apples.stream().count());//reduce 将流中所有元素反复结合起来,得到一个值。可以用累加来帮助理解reduce操作//累加1-100intsum=0;List numbers= Arrays.asList(1,2,3,4,5,6,7);for(inti : numbers){

sum+=i;}

System.out.println("sum:"+sum);//用reduce实现累加System.out.println("reduce sum:"+numbers.stream().reduce(0,(a,b)->a+b));//用reduce查找最大值System.out.println("max:"+numbers.stream().reduce(0,(a,b)-> a>=b ? a : b));//Interge中提供了静态的sum和max方法,代码可以进一步简化System.out.println("reduce sum:"+numbers.stream().reduce(0,Integer::sum));/*基本类型数组流.上面代码计算总和的方式包含了一个自动的从int转成Integer的操作,Java 8引入了三个原始类型特化流接口来解决这个问题:IntStream、 DoubleStream 和LongStream,分别将流中的元素特化为 int 、 long 和 double ,从而避免了暗含的装箱成本。将流转换为特化版本的常用方法是 mapToInt 、 mapToDouble 和 mapToLong 。这些方法和前面说的 map 方法的工作方式一样,只是它们返回的是一个特定类型的流,而不是 Stream,此外它们多了一些直接的运算方法,如sum()*/System.out.println("mapToInt sum:"+apples.stream().mapToInt(Apple::getWeight).sum());//所有返回流的方法都可以随意组合使用//计算weight>1并且颜色是red的所有苹果的总重量System.out.println("weight:"+apples.stream().filter(apple -> apple.getWeight()>1).filter(apple -> apple.getColor().equals("red")).map(apple -> apple.getWeight()).reduce(0,Integer::sum));}

}

运行结果:

[重量:1,颜色:red,品类:红富士, 重量:3,颜色:red,品类:红富士, 重量:2,颜色:red,品类:山东苹果, 重量:4,颜色:red,品类:山东苹果]

[重量:1,颜色:red,品类:红富士, 重量:2,颜色:red,品类:山东苹果, 重量:5,颜色:green,品类:红富士, 重量:6,颜色:green,品类:山东苹果]

[重量:1,颜色:red,品类:红富士]

[重量:6,颜色:green,品类:山东苹果, 重量:8,颜色:green,品类:山东苹果]

[red, red, red, red, green, green, green, green]

true

false

false

重量:1,颜色:red,品类:红富士

重量:3,颜色:red,品类:红富士

count:8

sum:28

reduce sum:28

max:7

reduce sum:28

mapToInt sum:36

weight:9

@不迷失|知识改善生活

微信公众号:java技术

0818b9ca8b590ca3270a3433284dd417.png专注技术研究与视频教学,分享有价值的技术与经验,关注程序员的发展!

@不迷失教学视频

0818b9ca8b590ca3270a3433284dd417.png

推荐阅读

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值