
在日常的java开发中,我们经常会遇到需要对集合中的数据进行分类统计的需求。例如,给定一个包含家庭成员信息的列表,我们可能需要统计不同类型成员(如兄弟姐妹、子女、配偶)各自的数量。原始数据可能以list<map<string, string>>的形式存在,其中每个map代表一个成员,键如"add_family_member"、"full_name"等。
虽然List<Map<String, String>>能够存储结构化数据,但它缺乏类型安全,且在访问数据时需要依赖字符串键,容易出错且代码可读性差。为了更好地组织和处理数据,强烈建议使用POJO(Plain Old Java Object)类来表示数据实体。
以家庭成员为例,我们可以定义一个FamilyMember类,其属性与数据字段对应:
import java.time.LocalDate;
public class FamilyMember {
private String memberType;
private String fullName;
private LocalDate dateOfBirth;
private String gender;
public FamilyMember(String memberType, String fullName,
LocalDate dateOfBirth, String gender) {
this.memberType = memberType;
this.fullName = fullName;
this.dateOfBirth = dateOfBirth;
this.gender = gender;
}
// Getters for all fields
public String getMemberType() {
return memberType;
}
public String getFullName() {
return fullName;
}
public LocalDate getDateOfBirth() {
return dateOfBirth;
}
public String getGender() {
return gender;
}
// Setters (optional, depending on immutability needs)
public void setMemberType(String memberType) {
this.memberType = memberType;
}
public void setFullName(String fullName) {
this.fullName = fullName;
}
public void setDateOfBirth(LocalDate dateOfBirth) {
this.dateOfBirth = dateOfBirth;
}
public void setGender(String gender) {
this.gender = gender;
}
@Override
public String toString() {
return "FamilyMember{" +
"memberType='" + memberType + '\'' +
", fullName='" + fullName + '\'' +
'}';
}
}使用POJO的好处显而易见:
Java 8引入的Stream API提供了一种声明式处理集合数据的方式,使得数据聚合操作变得非常简洁和高效。要统计列表中特定字段的出现次数,我们可以结合使用Collectors.groupingBy()和Collectors.counting()。
立即学习“Java免费学习笔记(深入)”;
下面是使用Java 8 Stream API统计家庭成员类型的完整示例:
import java.time.LocalDate;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
public class TestFamilyMemberCount {
public static void main(String[] args) {
// 1. 创建FamilyMember对象实例
FamilyMember member1 = new FamilyMember("Sibling", "Sibling name",
LocalDate.of(1990, 12, 12), "Male");
FamilyMember member2 = new FamilyMember("Sibling", "Sibling name2",
LocalDate.of(1990, 12, 12), "Male");
FamilyMember member3 = new FamilyMember("Sibling", "Sibling name3",
LocalDate.of(1990, 12, 12), "Male");
FamilyMember member4 = new FamilyMember("Child", "Child name",
LocalDate.of(2010, 12, 12), "Male");
FamilyMember member5 = new FamilyMember("Child", "Child name2",
LocalDate.of(2000, 12, 12), "Female");
FamilyMember member6 = new FamilyMember("Spouse", "Spouse name",
LocalDate.of(1990, 12, 12), "Male");
// 2. 将FamilyMember对象放入列表中
List<FamilyMember> listOfFamilyMember = Arrays.asList(member1, member2,
member3, member4, member5, member6);
// 3. 使用Stream API进行分组和计数
Map<String, Long> countMembers = listOfFamilyMember.stream()
.collect(Collectors.groupingBy(FamilyMember::getMemberType,
Collectors.counting()));
// 4. 打印结果
System.out.println(countMembers);
}
}代码解析:
输出示例:
{Spouse=1, Sibling=3, Child=2}这清晰地显示了每种家庭成员类型的数量。
通过本教程,我们学习了如何利用Java 8 Stream API中的Collectors.groupingBy和Collectors.counting,结合POJO数据模型,高效且优雅地统计列表中特定字段的出现次数。这种方法不仅代码简洁,而且具有良好的可读性和可维护性,是现代Java开发中处理集合数据聚合的推荐实践。
以上就是Java 8 Stream:高效统计List中特定字段出现次数的教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号