不能直接 new collections(),因为它是私有构造函数的静态工具类;其核心用途包括创建不可变/同步集合、频率统计、交集判断等集合接口不提供的全局操作。

为什么不能直接 new Collections()?
Collections 是一个纯工具类,所有方法都是 static,构造函数被显式声明为 private。试图 new Collections() 会编译报错:Constructor Collections() is not visible。它不封装状态,只提供对 List、Set、Map(部分)等集合的通用操作。
哪些操作必须用 Collections 而不是集合自身方法?
集合接口(如 ArrayList、HashSet)不提供的“全局性”能力,基本都靠 Collections:
-
Collections.unmodifiableList(list):返回不可修改视图(注意:不是深拷贝,原集合改了,视图也变) -
Collections.synchronizedList(list):包装成线程安全版本(但迭代时仍需手动同步) -
Collections.singleton("x"):创建只含一个元素的不可变Set(比Set.of("x")更早可用,兼容 Java 5+) -
Collections.frequency(list, "a"):统计某元素出现次数(list自身无此方法) -
Collections.disjoint(set1, set2):判断两个集合是否无交集(避免手写循环)
排序和查找要注意泛型与 Comparable 约束
Collections.sort(list) 要求 list 元素实现 Comparable,否则运行时报 ClassCastException。常见踩坑点:
- 用
Arrays.asList(new Object[]{1, "a"})后调sort()→ 报错,因为Integer和String无法比较 - 自定义类未实现
Comparable,又没传Comparator→ 同样崩溃 -
Collections.binarySearch()前必须确保已排序,且用同一Comparator(如果有的话),否则结果无意义
安全做法:优先用带 Comparator 的重载,例如 Collections.sort(list, Comparator.naturalOrder())。
立即学习“Java免费学习笔记(深入)”;
emptyXXX 和 singletonXXX 返回的是不可变集合
Collections.emptyList()、Collections.emptySet()、Collections.emptyMap() 返回的是轻量级单例对象,不是每次新建。它们不可修改,任何修改操作(如 add())都会抛 UnsupportedOperationException。这点和 Java 9+ 的 List.of() 行为一致,但兼容性更好。
注意:Collections.EMPTY_LIST(全大写静态字段)是遗留写法,已过时,应统一用 emptyList() 方法。
真正容易被忽略的是:这些空集合虽然不可变,但类型擦除后可能引发泛型警告;若需明确类型,建议用 Collections.<string>emptyList()</string> 显式指定。










