news 2026/4/18 5:43:01

Java 中将 List 中对象的某一列转换为 Set

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Java 中将 List 中对象的某一列转换为 Set

在 Java 中将 List 中对象的某一列转换为 Set,有几种常用方法:

1. 使用 Stream API(最常用)

import java.util.*; import java.util.stream.Collectors; // 示例类 class Person { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } } public class Main { public static void main(String[] args) { List<Person> personList = Arrays.asList( new Person("张三", 25), new Person("李四", 30), new Person("王五", 25), new Person("张三", 28) // 重复的张三 ); // 方法1:提取 name 列到 Set(自动去重) Set<String> nameSet = personList.stream() .map(Person::getName) // 提取 name .collect(Collectors.toSet()); System.out.println(nameSet); // [张三, 李四, 王五] // 方法2:提取 age 列到 Set Set<Integer> ageSet = personList.stream() .map(Person::getAge) .collect(Collectors.toSet()); System.out.println(ageSet); // [25, 30, 28] } }

2. 指定具体的 Set 实现

// 使用 HashSet Set<String> nameSet = personList.stream() .map(Person::getName) .collect(Collectors.toCollection(HashSet::new)); // 使用 TreeSet(排序) Set<String> sortedNameSet = personList.stream() .map(Person::getName) .collect(Collectors.toCollection(TreeSet::new)); // 使用 LinkedHashSet(保持插入顺序) Set<String> linkedNameSet = personList.stream() .map(Person::getName) .collect(Collectors.toCollection(LinkedHashSet::new));

3. 处理可能为 null 的情况

// 方法1:过滤掉 null Set<String> nameSet = personList.stream() .map(Person::getName) .filter(Objects::nonNull) // 过滤 null .collect(Collectors.toSet()); // 方法2:使用 filter 和 Optional Set<String> nameSet = personList.stream() .map(Person::getName) .filter(name -> name != null && !name.trim().isEmpty()) // 过滤 null 和空字符串 .collect(Collectors.toSet());

4. 复杂对象属性提取

// 如果属性是嵌套对象 class Department { private String deptName; // getters and setters } class Employee { private String name; private Department department; // getters and setters } // 提取嵌套属性 Set<String> deptNames = employeeList.stream() .map(Employee::getDepartment) .filter(Objects::nonNull) .map(Department::getDeptName) .collect(Collectors.toSet());

5. 并行流处理(大数据量时)

Set<String> nameSet = personList.parallelStream() // 并行处理 .map(Person::getName) .collect(Collectors.toSet());

6. 传统方法(不使用 Stream)

// 传统 for 循环 Set<String> nameSet = new HashSet<>(); for (Person person : personList) { nameSet.add(person.getName()); } // 传统 for 循环,处理 null Set<String> nameSet = new HashSet<>(); for (Person person : personList) { if (person.getName() != null) { nameSet.add(person.getName()); } }

主要区别对比

方法

优点

缺点

Stream API

代码简洁,可读性好,支持链式调用

Java 8+

并行流

大数据量性能好

线程安全需注意

传统循环

兼容性好,Java 8 以下可用

代码冗长

最佳实践建议

  1. 推荐使用 Stream API:代码简洁,可读性好

  2. 考虑使用 LinkedHashSet:如果需要保持顺序

  3. 总是处理 null 值:避免 NullPointerException

  4. 大数据量考虑并行流:但要注意线程安全问题

  5. 使用具体类型:明确指定 Set 的实现类型,便于维护

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 20:01:48

基于单片机的多功能报警系统设计与实现

一、系统设计目标与需求分析 在安防、家居、工业监测等场景中&#xff0c;单一功能报警系统已无法满足多维度安全需求。基于单片机的多功能报警系统&#xff0c;核心目标是整合多类型风险监测与灵活报警响应&#xff0c;解决传统报警设备功能单一、误报率高、联动性差的问题。从…

作者头像 李华
网站建设 2026/4/18 0:54:24

方法的多态

一、多态前言&#xff1a;多态:同一个方法不同形态体现&#xff0c;多态分静态多态和动态的多态静态多态:函数重载和符号重载动态多态&#xff1a;抽象和虚方法静态多态1.多态之函数重载函数重载&#xff1a;在同一个范围内&#xff0c;函数名一样&#xff0c;参数的类型不一样…

作者头像 李华
网站建设 2026/4/17 11:39:48

MindSpore进阶:在 Ascend 上实现高性能自定义训练步

在昇腾&#xff08;Ascend&#xff09;算力平台上进行深度学习模型开发时&#xff0c;MindSpore 提供了非常便捷的高阶 API&#xff08;如 Model.train&#xff09;。但在实际的算法落地和科研探索中&#xff0c;我们往往需要更细粒度的控制权&#xff0c;比如&#xff1a;需要…

作者头像 李华
网站建设 2026/3/20 22:55:49

hdWGCNA:单细胞WGCNA分析方法

0. 数据准备 输入数据集的要求&#xff1a;已经进行了如下分析的Seurat对象 导入演示数据 #官方演示数据集 wget https://swaruplab.bio.uci.edu/public_data/Zhou_2020.rds seurat_obj <- readRDS(Zhou_2020.rds)这是一个正常的脑组织数据集&#xff0c;包含了使用Harmon…

作者头像 李华
网站建设 2026/4/18 2:34:54

探索半桥LLC开关电源模块设计:从原理到实践

半桥LLC开关电源模块设计资料DSP数字LLC电源源代码原理图软件学习&#xff0c;功率100W&#xff0c;包含磁件设计、软件设计报告、硬件设计报告、硬件原理、主功率计算书、LLC环路设计、仿真、BOM、使用说明&#xff0c;调试波形等全面且详细的全套资料最近在研究电源设计领域&…

作者头像 李华