Java8 用Lambda表达式给List集合排序的实现
Lambda用到了JDK8自带的一个函数式接口Comparator
准备一个Apple类
publicclassApple{ privateintweight; privateStringcolor; publicApple(){} publicApple(intweight){ this.weight=weight; } publicApple(intweight,Stringcolor){ this.weight=weight; this.color=color; } setters();getters();toString(); }
步骤一:
publicclassAppleComparatorimplementsComparator{ @Override publicintcompare(Appleo1,Appleo2){ returno1.getWeight()-o2.getWeight(); } }
步骤二:准备一个List集合
ArrayListinventory=Lists.newArrayList( newApple(10,"red"), newApple(5,"red"), newApple(1,"green"), newApple(15,"green"), newApple(2,"red"));
步骤三:顺序排序,三种方式
/** *顺序排序 */ //1、传递代码,函数式编程 inventory.sort(newAppleComparator()); System.out.println(inventory); //2、匿名内部类 inventory.sort(newComparator(){ @Override publicintcompare(Appleo1,Appleo2){ returno1.getWeight()-o2.getWeight(); } }); //3、使用Lambda表达式 inventory.sort((a,b)->a.getWeight()-b.getWeight()); //4、使用Comparator的comparing Comparator comparing=comparing((Applea)->a.getWeight()); inventory.sort(comparing((Applea)->a.getWeight())); //或者等价于 inventory.sort(comparing(Apple::getWeight));
步骤四:逆序排序
/** *逆序排序 */ //1、根据重量逆序排序 inventory.sort(comparing(Apple::getWeight).reversed());
步骤五:如果两个苹果一样重,就得再找一个条件来进行排序
//2、如果两个苹果的重量一样重,怎么办?那就再找一个条件进行排序呗 inventory.sort(comparing(Apple::getWeight).reversed().thenComparing(Apple::getColor));
https://gitee.com/play-happy/base-project
参考:
【1】《Java8实战》
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。