2021.5.24笔记 Set集合


HashSet集合

在这里插入图片描述

public class HashSetPractice {
    public static void main(String[] args) {
        Set<Integer> str1 = new HashSet<>();
        str1.add(1);
        str1.add(2);
        str1.add(3);
        str1.add(1);       //不允许添加重复元素,添加失败
        System.out.println(str1);
        //不可以用for循环,但是可以用迭代器和增强for循环遍历
        Iterator<Integer> iterator = str1.iterator();
        while (iterator.hasNext()) {
            Integer next = iterator.next();
            System.out.println(next);
        }

        System.out.println("================");

        for (Integer integer : str1) {
            System.out.println(integer);
        }
    }
}

哈希值

在这里插入图片描述

public class Person {
    @Override
    public int hashCode() {
        return 2;
    }
}
public class HashClass {
    public static void main(String[] args) {
        Person per = new Person();
        int codeNum = per.hashCode();
        System.out.println(codeNum);
        System.out.println(per);
        //该十进制数字与十六进制的地址值相对应
        //这时候如果类重写并return具体的数字,那么哈希值将变为相应的数值

        String str1 = new String("abc");
        int code1 = str1.hashCode();
        String str2 = new String("abc");
        int code2 = str2.hashCode();
        System.out.println(code1);
        System.out.println(code2);
        boolean isEqual = (str1 == str2);   //虽然哈希值相等,但是其变量对应的地址值不等
        System.out.println(isEqual);
    }
}

HashSet集合存储数据的结构(哈希表)

在这里插入图片描述


Set集合存储元素不重复的原理

在这里插入图片描述


HashSet存储自定义类型元素

在这里插入图片描述

public class Person {
    private String name;
    private int age;

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Person person = (Person) o;
        return age == person.age && Objects.equals(name, person.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public Person() {
    }
}
public class NewObj {
    public static void main(String[] args) {
        HashSet<Person> object1 = new HashSet<>();
        Person p1 = new Person("小新",6);
        Person p2 = new Person("小新",6);
        Person p3 = new Person("妮妮",6);
        System.out.println(p1.hashCode());
        System.out.println(p1.hashCode());
        System.out.println(p1.equals(p2));
        object1.add(p1);
        object1.add(p2);
        object1.add(p3);
        System.out.println(object1);
    }
}

LinkedList集合

在这里插入图片描述
只需要记住特点即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值