Java 集合 - Set
# Set
Set 注重独一无二的性质,该体系集合可以知道某物是否已经存在于集合中,不会存储重复的元素,用于存储无序**(存入和取出的顺序不一定相同)**元素,值不能重复。
对象的相等性:
引用到堆上同一个对象的两个引用是相等的。如果对两个引用调用 hashcode 方法,会得到相同的结果,如果对象所属的类没有覆盖 object 的 hashcode 方法的话,hashcode 会返回每个对象特有的序号(Java 是依据对象的内存地址计算出的此序号),所以两个不同的对象的 hashcode 值是不可能相等的
如果想要让两个不同的 Person 对象视为相等的,就必须覆盖 Object 继承下来的 hashcode 方法和 equals 方法,因为 Object hashcode 返回的是该对象的内存地址,所以必须重写 hashcode 方法,才能保证两个不同的对象具有相同的 hashcode,同时也需要两个不同对象比较 equals 方法返回 true
该集合中没有特有的方法,直接继承自 Collection
/**
* Collection
* \--List
* 有序(存储顺序和取出顺序一致),可重复
* \--Set
* 无序(存储顺序和取出顺序不一致),唯一
* HashSet:它不保证set的迭代顺序;特别是它不保证该顺序恒久不变
* 注意:虽然set集合的元素无序,但是,作为集合来说,它肯定有它自己的存储顺序,
* 而你的顺序恰巧和它的存储顺序一致,这代表不了有序,你可以多存储一些数据就能看到效果
**/
1
2
3
4
5
6
7
8
9
10
2
3
4
5
6
7
8
9
10
案例:Set 集合添加元素并使用增强 for 循环遍历
public static void method1() {
Set<String> set = new HashSet<>();
set.add("1");
set.add("5");
set.add("2");
set.add("5"); //重复的不会添加进去
for (String s : set) {
System.out.println(s);
}
}
1
2
3
4
5
6
7
8
9
10
11
2
3
4
5
6
7
8
9
10
11
最后输出顺序是:1、2、5
编辑此页 (opens new window)
更新时间: 2024/11/02, 18:07:00