zoukankan      html  css  js  c++  java
  • 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、测试运行:

    效果相同!

  • 相关阅读:
    View基础知识
    数据库性能优化之SQL优化
    poi读取Excel文件和图片
    ab压测工具的一些个人见解
    【压测工具对比系列施压对比】
    【压测工具对比系列性能对比】
    【转】linux sed命令详解
    linux下文件比对功能
    windows下自动更改IP的小工具(bat批处理文件)
    mysql中操作符LIKE与通配符%的使用
  • 原文地址:https://www.cnblogs.com/wang-zai/p/8261913.html
Copyright © 2011-2022 走看看