电话
400 9058 355
Java集合框架是围绕Collection和Map接口构建的契约体系,接口定义操作,实现类负责高效实现;List与Set核心区别在于唯一性语义而非顺序;哈希类集合依赖hashCode()与equals()一致性。
Java集合框架不是一堆类的堆砌,而是围绕 Collection 和 Map 两大接口构建的「契约体系」:接口定义「能做什么」(比如 add()、contains()),实现类负责「怎么高效做」(比如 ArrayList 用数组、LinkedList 用链表)。你写代码时面向接口编程,换实现类几乎不用改逻辑。
很多人记成“List 有序、Set 无序”,但关键其实是:Set 的设计目标是数学意义上的集合——元素必须唯一,靠 equals() + hashCode() 判重;而 List 允许重复,且天然保留插入顺序(所以能用 get(int index))。
HashSet 看似“无序”,其实是哈希散列导致的遍历顺序不稳定,不是随机;它只保证 add() 和 contains() 平均 O(1)TreeSet 是真有序(红黑树),但要求元素可比较(实现 Comparable 或传 Comparator),否则运行时报 ClassCastException
ArrayList 查找快(O(1) 随机访问),但中间 remove(int index) 是 O(n) —— 因为要数组拷贝移位Collection 和 Map 是接口,不能 new;常见错误是写 new Collection() 编译直接报错。选实现类要看场景:
ArrayList,不是 LinkedList(后者 get() 是 O(n))remove(),会抛 ConcurrentModificationException —— 改用 Iterator.remove() 或 removeIf()
HashMap?危险!它不保证线程安全;应选 ConcurrentHashMap,而不是加 synchronized 块锁整个方法Map 虽然不属于 Collection 体系(它存的是键值对),但它的视图方法返回真正的 Collection 实例:
Mapmap = new HashMap<>(); map.put("a", 1); map.put("b", 2); // 这三个都是 Collection 类型,可直接用 Collection 方法 Collection keys = map.keySet(); // Set Collection values = map.values(); // Collection Collection > entries = map.entrySet(); // Set
注意:keySet() 和 entrySet() 返回的是 Set,意味着 key 和 entry 都不可重复;而 values() 是普通 Collection,值可以重复。
最容易被忽略的一点:所有基于哈希的集合(HashSet、HashMap、LinkedHashSet)都依赖对象的 hashCode() 和 equals() 一致性。如果只重写 equals() 忘了重写 hashCode(),或者修改了参与计算的字段后又把对象放进集合,结果就是“明明存在却 contains() 返回 false”。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...