一篇文章让你精通:java集合讲解(四,Set)

13 篇文章 0 订阅

一篇文章让你精通:java集合讲解(三,Set)_韶光不负的博客-CSDN博客

书接上文, 我发现如果一下子写太多东西,自己不好记,而且喜欢看小编文章的大大们也不好看,这怎么能行呢?可以辛苦我,不能辛苦大大们,所以此篇文章是上一篇文章的后续。

目录

set定义外部比较器

存储相同对象时,存储的是哪一个?(在对象中写叫内部比较器)

外部比较器(外部比较器比内部比较器优先)

方法三,lamdba表达式

源码了解


set定义外部比较器

上文当中的TrereSet进行讲解。set是无序的但它子类TrereSet是有序的。当我们定义类时,没有重写compareTo方法,所以导致报错,所以今天在对TreeSet的比较器在进行了解。

存储相同对象时,存储的是哪一个?(在对象中写叫内部比较器)

  //重写TreeSet的比较规则,比较年龄
    @Override
    public int compareTo(Student other){
        return this.age-other.age;
    }

在运行程序时,发现当比较相同数据时,只存储第一个输入的值

外部比较器(外部比较器比内部比较器优先)

当我们定义的比较器,比较一个相同数据,但不同对象时(比如说比较年龄,当然不能只存储一个年龄18的人)。就需要使用外部比较器,进行比较(外部比较器可以多个

自定义一个外部比较器



import java.util.Comparator;

public class StuScoreNameDescComparator implements Comparator<Student> {
    @Override
    public int compare(Student stu1, Student stu2) {
//比较分数
        if(stu1.getScore()>stu2.getScore()){
            return 1;
        }else if(stu1.getScore()<stu2.getScore()){
            return -1;
        }else {
            return stu1.getName().compareTo(stu2.getName());/再比较比较年龄
        }

    }
}

引用到TreeSet中

public class Test {
    public static void main(String[] args)  {
         //Comparator comp=new StuScoreNameDescComparator();
         //方法二,使用匿名内部类
        Comparator comp= new Comparator<Student>() {
            @Override
            public int compare(Student stu1, Student stu2) {
                if(stu1.getScore()>stu2.getScore()){
                    return 1;
                }else if(stu1.getScore()<stu2.getScore()){
                    return -1;
                }else {
                    return stu1.getName().compareTo(stu2.getName());
                }
            }
        };
        //创建Set集合数组,存储学生信息。
       
        Set<Student> set= new TreeSet<>(comp);//外部比较强优先
    }
}

方法三,lamdba表达式

Set<Student> set= new TreeSet<Student>((stu1,stu2)->{ if(stu1.getScore()>stu2.getScore()){
            return 1;
        }else if(stu1.getScore()<stu2.getScore()){
            return -1;
        }else {
            return stu1.getName().compareTo(stu2.getName());
        }});

//方式二
 Set<Student> set= new TreeSet<Student>((stu1,stu2)->{return stu1.getName().compareTo(stu2.getName());});

源码了解

Set与Map源码有非常大的联系(Set的实现其实是创建了map):

Map的源码了解

HashSet

1,hashSet的底层使用的是hashMap,所以底层结构使用的是哈希表

 

2,hashSet的add方法添加元素时,添加的是map当中的key,value都指向Object一个对象(对象为null)

 问题:下面代码添加对象有什么区别?

    //下面二行代码一样吗?
    map.put(e, PRESENT)//1
    map.put(e, new Object())//2

 解析:不一样1中的方法添加的对象是同一个对象(不会在创建对象),而2中添加的对象,需要创建,这样就节省了内存空间。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

韶光不负

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值