Set集合

1.Set集合主要讲的是HashSet集合。

2.HashSet集合存储的数据是无序,不重复,没有索引。

3.如果像hashSet中存储数据的时候,是判断hashcode值和equals。

4.hashSet中存储数据,是将将要存储的数据和已经存在的数据挨个进行比较,才能存入进去。

5.在object中判断hashcode返回的是地址值,如果不重写hashcode值的话,每个数据的地址值都不一样,就可以存入进去了,所以需要重写hashcode,这样我们可以通过内容的hashcode值进行比较,如果相同,在继续比较equals。

6.hashcode值:

    如果是基本数据类型的话,hashcode值就是本身;

    如果是引用数据类型的话,需要调用对象的hashcode方法。

/**
 * 
 * @author Administrator
 *hashSet类型如果是基本类型,hashcode值就是本身
 *            如果是引用类型,hashcode值是hashcode值
 */
public class SetTest {
    
    public static void main(String[] args) {
        
        //1.创建一个hashSet集合
        HashSet<String> set = new HashSet<>();
        //2.向hashSet中添加数据
        set.add("李四");
        set.add("王五");
        set.add("李四");
        //3.输入hashSet
        System.out.println(set);//[李四, 王五]
        
        HashSet<Person> pSet = new HashSet<Person>();
        
        Person p = new Person();
        p.setAge(12);
        p.setName("留言");
        pSet.add(p);
        
        Person p1 = new Person();
        p.setAge(122);
        p.setName("留言");
        pSet.add(p1);
        
        Person p2 = new Person();
        p.setAge(12);
        p.setName("留言");
        pSet.add(p2);
        
        System.out.println(pSet.toString());//3个

        
    }

}

 

转载于:https://www.cnblogs.com/itcx1213/p/8012599.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值