Java集合框架核心包括List、Set、Map接口。1. List有序可重复,常用方法有add、get、set、remove等,ArrayList随机访问快,LinkedList插入删除高效;遍历修改需用Iterator或并发安全类。2. Set不允许重复,HashSet查找快,LinkedHashSet保持插入顺序,TreeSet支持排序,常用方法包括add、contains、remove等。3. Map存储键值对,HashMap性能高但无序,LinkedHashMap有序,TreeMap按键排序,核心方法有put、get、containsKey、entrySet等。4. 遍历推荐增强for或Iterator,Map宜用entrySet;非线程安全集合需用同步工具或并发容器如ConcurrentHashMap。掌握这些方法可提升开发效率与程序性能。

Java集合框架是开发中使用最频繁的工具之一,掌握其常用方法能显著提升编码效率和程序性能。以下对List、Set、Map等核心接口的常用方法进行解析,帮助理解其使用场景与注意事项。
1. List 接口常用方法
List 是有序集合,允许重复元素,最常用的实现类是 ArrayList 和 LinkedList。
常用方法包括:
- add(E e):在末尾添加元素,也可指定索引插入 add(int index, E element)
- get(int index):通过索引获取元素,ArrayList 效率高,LinkedList 随机访问较慢
- set(int index, E element):替换指定位置的元素
- remove(int index) 或 remove(Object o):删除元素
- indexOf(Object o):返回首次出现的索引,不存在则返回 -1
- size():返回元素个数
- contains(Object o):判断是否包含某元素
注意:操作过程中避免在遍历时直接修改集合,应使用 Iterator 或并发安全类如 CopyOnWriteArrayList。
立即学习“Java免费学习笔记(深入)”;
2. Set 接口常用方法
Set 不允许重复元素,常用实现有 HashSet、LinkedHashSet 和 TreeSet。
主要方法如下:
- add(E e):添加元素,若已存在则返回 false
- remove(Object o):删除指定元素
- contains(Object o):检查是否包含某元素,HashSet 基于哈希表,平均时间复杂度 O(1)
- size() 和 isEmpty():获取大小和判断是否为空
TreeSet 支持排序,元素需实现 Comparable 接口或传入 Comparator。遍历时顺序为自然序或自定义序。
Sylius开源电子商务平台是一个开源的 PHP 电子商务网站框架,基于 Symfony 和 Doctrine 构建,为用户量身定制解决方案。可管理任意复杂的产品和分类,每个产品可以设置不同的税率,支持多种配送方法,集成 Omnipay 在线支付。功能特点:前后端分离Sylius 带有一个强大的 REST API,可以自定义并与您选择的前端或您的微服务架构很好地配合使用。如果您是 Symfony
3. Map 接口常用方法
Map 存储键值对,键不可重复,常用实现为 HashMap、TreeMap 和 LinkedHashMap。
核心方法有:
- put(K key, V value):放入键值对,若键已存在则覆盖旧值并返回原值
- get(Object key):根据键获取值,键不存在返回 null
- remove(Object key):删除键对应的映射
- containsKey(Object key) 和 containsValue(Object value):判断是否包含键或值
- keySet():返回所有键的 Set 视图
- values():返回所有值的 Collection 视图
- entrySet():返回键值对的 Set,适合遍历整个 Map
- size() 和 isEmpty():常规信息查询
HashMap 性能高效,但不保证顺序;LinkedHashMap 维护插入顺序;TreeMap 按键排序。
4. 集合遍历与线程安全
遍历集合时推荐方式:
- 使用增强 for 循环:for (String s : list)
- 使用 Iterator,尤其在条件删除时更安全
- Map 遍历建议用 entrySet() 提升性能
默认集合类(如 ArrayList、HashMap)不是线程安全的。多线程环境下可使用 Collections.synchronizedList() 包装,或选择 ConcurrentHashMap、CopyOnWriteArrayList 等并发容器。
基本上就这些。熟悉这些方法的用途和差异,能让你在实际开发中更灵活地处理数据结构问题。









