Collections.frequency()用于统计集合中某元素出现次数,需传入集合与目标元素,依赖equals方法比较,支持List等允许重复的集合,遍历时间复杂度O(n),适用于已重写equals的自定义对象。

在Java中,Collections.frequency() 是一个静态方法,用于统计指定集合中某个元素出现的次数。这个方法属于 java.util.Collections 类,使用起来非常方便,适用于任何实现了 Collection 接口的集合类型,比如 ArrayList、LinkedList、HashSet 等。
方法签名
public static int frequency(Collection> c, Object o)该方法接收两个参数:
- c:要搜索的集合
- o:要统计出现次数的元素
返回值是元素 o 在集合 c 中出现的次数(int 类型)。
基本使用示例
以下是一个简单的例子,演示如何统计某个字符串在 List 中出现的次数:
立即学习“Java免费学习笔记(深入)”;
Listint count = Collections.frequency(words, "apple");
System.out.println("apple 出现了 " + count + " 次"); // 输出:3
支持的集合类型
该方法适用于大多数集合类型:
- ArrayList、LinkedList:支持重复元素,适合 frequency 统计
- HashSet、LinkedHashSet:不存储重复元素,每个元素最多出现一次
- Queue 实现类如 ArrayDeque 也可以使用
注意:虽然可以传入 Set 集合,但由于 Set 不允许重复,结果只会是 0 或 1。
注意事项和常见问题
使用时需要注意以下几点:
- 集合不能为 null,否则会抛出 NullPointerException
- 元素对象的 equals 方法必须正确定义,frequency 依赖 equals 判断相等性
- 对于自定义对象,确保重写了 equals() 方法,否则比较可能不符合预期
- 性能上,该方法需要遍历整个集合,时间复杂度为 O(n)
自定义对象示例
如果你有一个 Person 类,并想统计某个“姓名”出现的次数:
class Person {String name;
public Person(String name) { this.name = name; }
@Override public boolean equals(Object o) {
if (!(o instanceof Person)) return false;
Person p = (Person)o;
return name.equals(p.name);
}
}
List
new Person("Alice"),
new Person("Bob"),
new Person("Alice")
);
int count = Collections.frequency(people, new Person("Alice")); // 注意:需正确实现 equals
System.out.println(count); // 输出:2










