java8根据对象属性过滤掉相同元素

有这样一种情况:某人工资一天涨100块钱,数据库中记录了员工姓名和工资,如:
如果此时只需要根据姓名查找员工的其中一条记录该怎么办呢,我们可以用sql语句distinct或groupby达到效果,如果用java集合怎么做呢,如果用java8新特性lambda表达式怎么做呢?

其实说白了,就是过滤掉相同元素的问题,姓名相同的员工视为同一个人,过滤掉其他记录,拿到此人其中一条记录即可

先给出直观效果:

为实现此功能,我们可以这样做:

1、新建用户类:

class User{
    private String username;
    private int money;

    public User(){}

    public User(String username, int money){
        this.username = username;
        this.money = money;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public int getMoney() {
        return money;
    }

    public void setMoney(int money) {
        this.money = money;
    }
}

2、实例化对象,添加到List集合:

List<User> users = Arrays.asList(
                new User("张三", 1000),
                new User("张三", 1100),
                new User("张三", 1200),
                new User("李四", 1000),
                new User("李四", 1100),
                new User("王五", 2500),
                new User("赵六", 1800));

3、用传统方式写一个过滤重复元素的方法:

public static List<User> removeDuplicateUser(List<User> users){
        Set<User> set = new TreeSet<User>(new Comparator<User>() {
            @Override
            public int compare(User o1, User o2) {
                return o1.getUsername().compareTo(o2.getUsername());
            }
        });

        set.addAll(users);
        return new ArrayList<>(set);
    }

4、用传统方式写一个打印List集合的方法:

public static void printList(List<User> list){
        for (User user : list) {
            System.out.println(user.getUsername() + ", " + user.getMoney());
        }
        System.out.println("-------------------------------");

    }

5、测试:

public static void main(String[] args) {
        List<User> users = Arrays.asList(
                new User("张三", 1000),
                new User("张三", 1100),
                new User("张三", 1200),
                new User("李四", 1000),
                new User("李四", 1100),
                new User("王五", 2500),
                new User("赵六", 1800));
        printList(users);
        List<User> users2 = removeDuplicateUser(users);
        printList(users2);

    }

6、运行结果:

可以看到,用传统遍历方式可以实现功能,而java8新特性增加了lambda表达式和stream流,提供了操作集合的方便操作,下面通过java8新特性简单实现相同功能:

1、过滤方法:

public static List<User> removeDuplicateUser(List<User> users){
        Set<User> set = new TreeSet<User>((user1, user2) -> user1.getUsername().compareTo(user2.getUsername()));

        set.addAll(users);
        return new ArrayList<>(set);
    }

2、打印方法:

public static void printList(List<User> list){
        list.stream().forEach(user -> System.out.println(user.getUsername() + ", " + user.getMoney()));
        System.out.println("-------------------------------");
    }

3、测试运行:

效果相同!

原文地址:https://www.cnblogs.com/wang-zai/p/8261913.html