在软件开发中,我们经常需要对数据结构进行转换以满足不同的业务需求。一个常见的场景是,我们可能拥有一个表示“项目-用户列表”关系的映射,即一个map
假设我们有以下初始数据结构:
Map> map = new HashMap<>(); map.put("projectA", Arrays.asList(new User(1,"Bob"), new User(2,"John"), new User(3,"Mo"))); map.put("projectB", Arrays.asList(new User(2,"John"), new User(3,"Mo"))); map.put("projectC", Arrays.asList(new User(3,"Mo")));
其中,User类定义如下:
public static record User(int id, String name) {}我们的目标是将其转换为以下形式:
Bob = [projectA] John = [projectA, projectB] Mo = [projectA, projectB, projectC]
对应的数据结构为 Map
实现这种转换的核心思路是遍历原始Map的每一个条目。对于每一个条目,我们获取其键(项目名称)和值(用户列表)。然后,我们遍历这个用户列表中的每一个用户。对于每个用户,我们将其作为新Map的键,并将当前的项目名称添加到该用户对应的项目列表中。
为了确保每个用户在新的Map中都有一个对应的项目列表,我们需要在添加项目名称之前检查该用户是否已存在于新Map中。如果不存在,则需要先为该用户创建一个新的空列表。Java的Map.putIfAbsent()方法非常适合处理这种情况。
下面是完整的Java代码示例,展示了如何进行上述转换:
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Objects;
public class ProjectUserTransformer {
// 定义User记录类,简化equals()和hashCode()的实现
public static record User(int id, String name) {
// record类型会自动生成equals(), hashCode(), toString()方法
}
public static void main(String[] args) {
// 原始数据:项目到用户列表的映射
Map> projectToUsersMap = new HashMap<>();
projectToUsersMap.put("projectA", Arrays.asList(new User(1,"Bob"), new User(2,"John"), new User(3,"Mo")));
projectToUsersMap.put("projectB", Arrays.asList(new User(2,"John"), new User(3,"Mo")));
projectToUsersMap.put("projectC", Arrays.asList(new User(3,"Mo")));
// 目标数据:用户到项目列表的映射
Map> userToProjectsMap = new HashMap<>();
// 遍历原始Map的每一个条目
for (Map.Entry> entry : projectToUsersMap.entrySet()) {
String projectName = entry.getKey(); // 获取当前项目名称
List usersInProject = entry.getValue(); // 获取当前项目中的用户列表
// 遍历当前项目中的每一个用户
for (User user : usersInProject) {
// 如果用户尚未存在于userToProjectsMap中,则为其创建一个新的ArrayList
userToProjectsMap.putIfAbsent(user, new ArrayList<>());
// 将当前项目名称添加到该用户对应的项目列表中
userToProjectsMap.get(user).add(projectName);
}
}
// 打印转换后的结果
System.out.println(userToProjectsMap);
}
} 运行结果示例:
{User[id=1, name=Bob]=[projectA], User[id=2, name=John]=[projectA, projectB], User[id=3, name=Mo]=[projectA, projectB, projectC]}请注意,User[id=2, name=John]对应的项目列表顺序可能因Map的遍历顺序而异,但包含的项目是正确的。
public static record User(int id, String name) {}:
Map
Map
for (Map.Entry
for (User user : usersInProject):
userToProjectsMap.putIfAbsent(user, new ArrayList());:
userToProjectsMap.get(user).add(projectName);:
本教程详细介绍了如何将Map