【Java】【Stream流】分组

Java实际开发中使用流会提升代码的质量,所以这里继续分享使用流 玩分组

import java.util.Arrays;  
import java.util.List;  
import java.util.stream.Collectors;  
  
public class StreamGroupingExample {  
    public static void main(String[] args) {  
        List<User> users = Arrays.asList(  
            new User("Alice", 25),  
            new User("Bob", 30),  
            new User("Charlie", 35),  
            new User("David", 25),  
            new User("Eve", 30)  
        );  
  
        // 使用年龄对用户进行分组  
        Map<Integer, List<User>> userGroups = users.stream()  
            .collect(Collectors.groupingBy(User::getAge));  
  
        // 输出分组结果  
        System.out.println(userGroups);  
    }  
}

以上代码,以某个对象的属性来分组,这样获取的结果map就方便,我们在内存中进行处理,以下代码是groupingBy的完整版

Map<Integer, List<User>> userGroups = users.stream().collect(
Collectors.groupingBy(User::getAge,
Collectors.mapping(Function.identity(),Collectors.toList()))
);
以上两段代码都能表述分组,根据需求不同,对每个不同的分组进行处理,这里就遍历得到的map即可。
for (Map.Entry<Integer, List<User>> entry : userGroups.entrySet()) {
            Integer key = entry.getKey();

            List<User> userList = entry.getValue();
            xxxxx
        }
    }

你可能感兴趣的:(java,spring,spring,boot,spring,cloud,mybatis,maven)