【问题标题】:Convert list of Object to Map<Key, List<Object>> with java 8 stream [duplicate]使用java 8流将对象列表转换为Map<Key,List<Object>> [重复]
【发布时间】:2021-02-17 03:19:24
【问题描述】:

所以我有一个用户列表,其中包含一些信息,包括公司 uid,这个值可以在多个用户中找到,因为它定义了用户所属的公司。我需要创建一个用户列表的地图,其中地图键是公司 uid。我已经设法使用以下代码做到了:

HashMap<String, List<LDAPUser>> allUsers = new HashMap<>();
    userService.findAllUsers().forEach(u -> {
        Optional.ofNullable(allUsers.putIfAbsent(u.getCompanyUid(),
                new ArrayList<>(Collections.singletonList(u))))
                .ifPresent(list -> list.add(u));
    });

即使它工作正常,我认为必须有一个更清洁的方法使用 flatMap、map 或 collect 方法从流中,但我无法让它工作,因为我没有看到如何创建一个包含所有用户的列表。

【问题讨论】:

    标签: java-8 stream hashmap flatmap collect


    【解决方案1】:

    有一个收集器来分组,考虑下面的例子

    Application.java

    import java.util.Arrays;
    import java.util.List;
    import java.util.Map;
    import java.util.stream.Collectors;
    
    public class Application {
    
        private static class User {
    
            private final String name;
    
            private final Integer companyId;
    
            public User(String name, Integer companyId) {
                this.name = name;
                this.companyId = companyId;
            }
    
            public String getName() {
                return name;
            }
    
            public Integer getCompanyId() {
                return companyId;
            }
    
            @Override
            public String toString() {
                return "User{" +
                        "name='" + name + '\'' +
                        ", companyId=" + companyId +
                        '}';
            }
        }
    
        public static void main(String[] args) {
            final List<User> users = Arrays.asList(new User("A", 1), new User("B", 1), new User("C", 2));
            final Map<Integer, List<User>> byCompanyId = users.stream()
                    .collect(Collectors.groupingBy(User::getCompanyId));
            System.out.println(byCompanyId);
        }
    }
    

    会打印出来

    {1=[User{name='A', companyId=1}, User{name='B', companyId=1}], 2=[User{name='C', companyId=2}]}
    

    【讨论】:

    • 哇,这么简单,我没想到可以这样!谢谢!
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-11-11
    • 2022-06-10
    • 1970-01-01
    • 1970-01-01
    • 2019-12-06
    • 1970-01-01
    相关资源
    最近更新 更多