加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Lambda表达式实现List集合的自定义排序

发布时间:2020-12-14 06:39:16 所属栏目:Java 来源:网络整理
导读:之前写code,实现List集合的自定义排序,都是给Collections.sort()传递一个实现Comparator的类对象,相对比较麻烦,终于决定迅速学习一下java8中的Lambda表达,昨天刚刚到手的书,只有132页,决定13天内必须看完。OK,我终于写了自己的第一个Lambda表达式,

之前写code,实现List集合的自定义排序,都是给Collections.sort()传递一个实现Comparator的类对象,相对比较麻烦,终于决定迅速学习一下java8中的Lambda表达,昨天刚刚到手的书,只有132页,决定13天内必须看完。OK,我终于写了自己的第一个Lambda表达式,开心~

1、测试code:

public class Main {
public static void main(String[] args) {
BinaryOperator add=(x,y)->x+y;
/**注意:add的类型为BinaryOperator,它不是两个数字的和,而是将两个数字相加的那段代码~~~~切记")

  • */
    System.out.println("-----我是x+y的和------");
    System.out.println(add.apply(3L,4L));
    ArrayList<Integer> list=new ArrayList<>();
    list.add(3);list.add(1);list.add(4);list.add(-1);
    //降序排列
    Collections.sort(list,(x,y)->y-x);
    Iterator<Integer> iterator=list.iterator();
    System.out.println("-----我是降序排列写法-----");
    while (iterator.hasNext())
        System.out.print(iterator.next()+",");
    System.out.println();

    //升序排列
    Collections.sort(list,y)->x-y);
    Iterator<Integer> iterator1=list.iterator();
    System.out.println("-----我是升序排列写法-----");
    while (iterator1.hasNext())
        System.out.print(iterator1.next()+",");
}

}

输出结果:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读