Java8 排序

Java8新特性,排序语法。

public class Human {

    private String name;

    private int age;

    public Human() {
        super();
    }

    public Human(final String name, final int age) {
        super();
        this.name = name;
        this.age = age;
    }

    public static int compareByNameThenAge(Human lhs, Human rhs) {
        if (lhs.name.equals(rhs.name)) {
            return lhs.age - rhs.age;
        } else {
            return lhs.name.compareTo(rhs.name);
        }
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Human [name=" + name + ", age=" + age + "]";
    }

}

Junit

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;

public class HumanTest {

    private List<Human> list;

    @Before
    public void setUp() throws Exception {
        list = new ArrayList<>();

        list.add(new Human("Eric", 23));
        list.add(new Human("Joy", 45));
        list.add(new Human("Evan", 63));
        list.add(new Human("Ada", 29));
        list.add(new Human("Bom", 33));
        list.add(new Human("Jeff", 102));
        list.add(new Human("Eric", 4));

        System.out.println(list);
    }

    @After
    public void tearDown() throws Exception {
        System.out.println(list);
    }

    @Test
    public void test() {
        // 不使用Lambda表达式的基本排序
        list.sort(new Comparator<Human>() {
            @Override
            public int compare(Human o1, Human o2) {
                return o1.getName().compareTo(o2.getName());
            }
        });
    }

    @Test
    public void test1() {
        // 使用Lambda表达式的基本排序
        list.sort((Human o1, Human o2) -> o1.getName().compareTo(o2.getName()));
    }

    @Test
    public void test2() {
        // 没有类型定义( Type Definitions)的基本排序
        list.sort((o1, o2) -> o1.getName().compareTo(o2.getName()));
    }

    @Test
    public void test3() {
        // 使用静态方法的引用来排序
        list.sort(Human::compareByNameThenAge);
    }

    @Test
    public void test4() {
        // 提取Comparator进行排序
        Collections.sort(list, Comparator.comparing(Human::getName));
    }

    @Test
    public void test5() {
        // 反转排序
        Comparator<Human> comparator = (h1, h2) -> h1.getName().compareTo(h2.getName());
        list.sort(comparator.reversed());
    }

    @Test
    public void test6() {
        // 多条件排序
        list.sort((l, r) -> {
            if (l.getName().equals(r.getName())) {
                return l.getAge() - r.getAge();
            } else {
                return l.getName().compareTo(r.getName());
            }
        });
    }

    @Test
    public void test7() {
        // 多条件组合排序
        list.sort(Comparator.comparing(Human::getName).thenComparing(Human::getAge));
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值