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

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

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

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

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

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 {
    @Override
    public int compare(Student stu1, Student stu2) {
//比较分数
        if(stu1.getScore()>stu2.getScore()){
            return 1;
        }else if(stu1.getScore() 

引用到TreeSet中

public class Test {
    public static void main(String[] args)  {
         //Comparator comp=new StuScoreNameDescComparator();
         //方法二,使用匿名内部类
        Comparator comp= new Comparator() {
            @Override
            public int compare(Student stu1, Student stu2) {
                if(stu1.getScore()>stu2.getScore()){
                    return 1;
                }else if(stu1.getScore() set= new TreeSet<>(comp);//外部比较强优先
    }
}
方法三,lamdba表达式
Set set= new TreeSet((stu1,stu2)->{ if(stu1.getScore()>stu2.getScore()){
            return 1;
        }else if(stu1.getScore() set= new TreeSet((stu1,stu2)->{return stu1.getName().compareTo(stu2.getName());});

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5082305.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-16
下一篇 2022-11-16

发表评论

登录后才能评论

评论列表(0条)

保存