一、Set和List的区别
List中可以存在相同的元素,而Set不可以。基于这个特性,Set可以被用来实现去重,可作为Map的键
二、常见的Set
常见的Set有HashSet、LinkedHashSet、TreeSet
这些具体的实现类都继承了Set接口,实现了插入、删除、求长度、判断是否为空等方法
System.out.println(set.add(new grade("zhangsan",85,88)));
System.out.println(set.add(new grade("zhangsan",85,88)));
输出
true
false
当试图插入相同元素时,第二次插入是无效的
下面给出这三种具体实现类的区别
HastSet
不能保证元素的排列顺序,顺序有可能发生变化
集合元素可以是null,但只能放入一个null
当向HashSet结合中存入一个元素时,HashSet会调用该对象的hashCode()方法来得到该对象的hashCode值,然后根据 hashCode值来决定该对象在HashSet中存储位置。
也就是说,HashSet的位置是由HashCode决定的