list 多种排序,java8 ,Lambda写法,升序降序,多条件排序

package com.xiong.test.group_sort;
 
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
 
/**
 * @author Tan
 * @version V1.0
 * @description: GroupTestMain
 * @date 2019/9/27
 */
public class SortTestMain {
 
    public static void main(String[] args) {
        List<Person> persons = new ArrayList<>();//列表
 
        persons.add(new Person("aaa", 12));
        persons.add(new Person("ccc", 20));
        persons.add(new Person("bbb", 8));
 
 
        //no 1. Collections排序
 
        System.out.println("Age排序前:");
        persons.forEach((person)->System.out.println(person));
 
        //Collections排序升序
        Collections.sort(persons, new Comparator<Person>() {
            @Override
            public int compare(Person o1, Person o2) {
                return o1.getAge().compareTo(o2.getAge());
            }
        });
 
        System.out.println("Age升序排序后:");
        persons.forEach((person)->System.out.println(person));
 
        //Collections排序降序
        Collections.sort(persons, new Comparator<Person>() {
            @Override
            public int compare(Person o1, Person o2) {
                return o2.getAge().compareTo(o1.getAge());
            }
        });
 
        //循环打印
        System.out.println("Age降序排序后:");
        persons.forEach((person)->System.out.println(person));
 
        System.out.println("***************************************************************");
 
        // no 2.Lambda写法,JAVA8的写法
        // persons.sort((Developer o1, Developer o2)->o1.getAge().compareTo(o2.getAge())); //可以更简洁,如下:
 
        //升序排序
        persons.sort((a, b) -> a.getName().compareTo(b.getName()));
        System.out.println("Name升序排序后:");
        persons.forEach((person)->System.out.println(person));
 
 
        //降序排序, a,b倒转即可
        persons.sort((a, b) -> b.getName().compareTo(a.getName()));
        System.out.println("Name降序排序后:");
        persons.forEach((person)->System.out.println(person));
 
        //升序排序
        persons.sort(Comparator.comparing(Person::getAge));
        System.out.println("Age升序排序:");
        persons.forEach((person)->System.out.println(person));
 
        //降序排序, 加上 .reversed() 即可
        persons.sort(Comparator.comparing(Person::getAge).reversed());
        System.out.println("Age降序排序:");
        persons.forEach((person)->System.out.println(person));
 
        //先配置再排序
        Comparator<Person> ageComparator = (o1, o2)->o1.getName().compareTo(o2.getName());
        persons.sort(ageComparator);                //按上面配置的顺序取值
        System.out.println("Name升序排序后:");
        persons.forEach((person)->System.out.println(person));
 
        System.out.println("Name降序排序后:");
        persons.sort(ageComparator.reversed());     //按上面配置的顺序反向取值
        persons.forEach((person)->System.out.println(person));
 
 
        // 多条件排序第二个写法,先按Age排序,再根据name排序
        persons.sort(Comparator.comparing(Person::getAge).thenComparing(Person::getName));
        System.out.println("多条件排序后:");
        persons.sort(ageComparator.reversed());     //按上面配置的顺序反向取值
        persons.forEach((person)->System.out.println(person));
 
    }
 
 
}

public class Person {
    private String name;
    private Integer age;
 
    public Person(String name, int age) {
        this.age = age;
        this.name = name;
    }
}
————————————————
版权声明:本文为CSDN博主「谭cyzz」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zhan107876/article/details/101556373

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值