Java 集合框架 Set
集合继承框架图
还是这个图,今天学的是set接口,还有他底下的两个类:HashSet、TreeSet。
set:无序,存和取不一致,不允许重复。
Set
List有特有的方法是因为他有索引这个特性,Set就没有特别的方法。
HashSet
可以通过HashSet来保证存入元素的唯一性。
HashSet的add方法会返回boolean值表示有没有添加成功。
Hashset不能添加重复的元素,在自定义类中要重写equals方法判断元素是否相等,否则HashSet会以地址值来判断元素是否相等。
除了equals方法要重写以外,还需要重写hashCode方法。hashCode方法是Object类中定义的用来计算哈希码(根据地址)的函数,在HashSet中添加元素时会调用hashCode计算该元素的哈希码值,决定这个元素放在哪个位置,如果两个元素哈希码值一样,HashSet就会调用equals方法判断这两个元素是否相等,如果相等就不添加,不相等就挂在这个位置上(木桶结构)。
重写hashCode()和equals()方法的标准:
hashCode:属性相同的对象返回值必须相同,属性不同的返回值尽量不同(提高效率,减少不必要的调用equals)
equals:属性相同返回true,属性不同返回false,返回false的时候存储
LinkedHashSet
LinkedHashSet可以保证存取顺序一致。
保证元素唯一用的是HashSet,但是存储结构用的是链表。
HashSet存取速度更快,开发中更常用的是HashSet。
将集合中的重复元素删除:
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("c");
list.add("a");
list.add("b");
LinkedHashSet<String> set = new LinkedHashSet<>();
set.addAll(list);
list.clear();
list.addAll(set);
System.out.println(list);
运行结果:[a, b, c]
TreeSet
TreeSet一样可以保证存入数据的唯一性,还可以对存入元素进行排序。(integer类型从小到大排序,String类型通过字典的顺序来排序)
HashSet和TreeSet对元素的要求是不一样的,HashSet要求自定义类重写HashCode方法和equals方法。TreeSet要求元素要有比较性(继承Comparable接口,重写compareTo方法)。
TreeSet存了第一个元素以后,每次存入元素都要与现有的元素比较,比原有元素大就存右边,比原有元素小就存左边,在compareTo方法中返回值为正数就存右边,返回值为负数就存左边,为0就不存。(二叉树结构)
private static class Student implements Comparable{
private int age;
private String name;
public Student(int age, String name){
this.age = age;
this.name = name;
}
@Override
public boolean equals(Object o) {
if (this.age== ((Student) o).age&&this.name==((Student)o).name) return true;
else return false;
}
public void setAge(int age) {
this.age = age;
}
public void setName(String name){
this.name = name;
}
public int getAge() {
return age;
}
public String getName() {
return name;
}
@Override
public int hashCode() {
return Objects.hash(age, name);
}
@Override
public String toString() {
return "Student{" +
"age=" + age +
", name='" + name + '\'' +
'}';
}
@Override
public int compareTo(Object o) {
int num = this.age-((Student)o).age;
return num==0 ? this.name.compareTo(((Student) o).name):num;
}
}
上一篇: Java学习笔记(四)
下一篇: Java学习笔记(二)