栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

JAVA学习笔记21.11.27(参考黑马程序员B站视频)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

JAVA学习笔记21.11.27(参考黑马程序员B站视频)

排序 一、自然排序Comparable         1.存储学生对象并遍历,使用TreeSet的无参构造方法。

                要求:按年龄从小到大排序,年龄相同时按姓名的字母顺序排序。

                代码实现:

                        Student类:

package ComparableStudy;

public class Student implements Comparable{
    private String name;
    private int age;

    public Student() {
    }

    public Student(String name, int age) {
        this.name = name;
        this.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;
    }

    @Override
    public int compareTo(Student o) {
        int num1;
        num1 = this.getAge() - o.getAge();
        //当年龄相同的时候比较姓名
       num1=(num1==0?this.name.compareTo(o.getName()):num1);
        return num1;
        //num1=0 --->表示相同元素,不插入
        //num1>0 --->表示不同元素,升序
        //num1<0 --->表示不同元素,降序
    }
}

                        Demo类:

package ComparableStudy;

import java.util.TreeSet;

public class Demo {
    public static void main(String[] args) {
        //创建集合对象
        TreeSet ts = new TreeSet<>();

        //创建学生对象
        Student s1 = new Student("qwe", 11);
        Student s2 = new Student("asd", 12);
        Student s3 = new Student("zxc", 11);
        Student s4 = new Student("wh", 10);
        Student s5 = new Student("asd", 12);

        //把对象存储到集合中
        ts.add(s1);
        ts.add(s2);
        ts.add(s3);
        ts.add(s4);
        ts.add(s5);

        //遍历
        for (Student s : ts) {
            System.out.println(s.getName() + "," + s.getAge());
        }

    }
}

 

        2.总结
  • 用TreeSet集合存储自定义对象,无参构造方法使用的是自然排序方法对元素进行排序
  • 自然排序就是让元素所属的类实现Comparable接口,重写compareTo(T o)方法
  • 重写方法时要按照需求来写
二、Comparator的使用         1.存储学生对象并遍历,使用TreeSet的有参构造方法。

                要求:按年龄从小到大排序,年龄相同时按姓名的字母顺序排序。

                代码实现:

                        Student类:

package ComparableStudy;

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

    public Student() {
    }

    public Student(String name, int age) {
        this.name = name;
        this.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;
    }

    
}

                Demo:

package ComparableStudy;

import java.util.Comparator;
import java.util.TreeSet;

public class Demo {
    public static void main(String[] args) {
        //创建集合对象
        TreeSet ts = new TreeSet<>(new Comparator() {
            @Override
            public int compare(Student s1, Student s2) {
                int num;
                num = s1.getAge() - s2.getAge();
                //当年龄相同的时候比较姓名
                num=(num==0?s1.getName().compareTo(s2.getName()):num);
                return num;
            }
        });

        //创建学生对象
        Student s1 = new Student("qwe", 11);
        Student s2 = new Student("asd", 12);
        Student s3 = new Student("zxc", 11);
        Student s4 = new Student("wh", 10);
        Student s5 = new Student("asd", 12);

        //把对象存储到集合中
        ts.add(s1);
        ts.add(s2);
        ts.add(s3);
        ts.add(s4);
        ts.add(s5);

        //遍历
        for (Student s : ts) {
            System.out.println(s.getName() + "," + s.getAge());
        }

    }
}
        2.总结
  • 用TreeSet集合存储自定义对象,带参构造方法使用的是比较器排序对元素进行排序
  • 比较器排序就是让集合构造方法接收Comparator的实现对象,重写compare(T o1,T 02)方法
  • 重写方法时要按照需求来写

 

 

                

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/606161.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号