TreeSet的自然排序(自定义对象 compareTo方法)

简介: 》要实现自然排序,对象集合必须实现Comparable接口,并重写compareTo()方法 》一般需求中描述的是“主要条件”,如:按姓名长度排序。  需注意次要条件 如:长度相同时,姓名内容,年龄等条件是否相等,这决定着是否存入TreeSet集合。

》要实现自然排序,对象集合必须实现Comparable接口,并重写compareTo()方法

》一般需求中描述的是“主要条件”,如:按姓名长度排序。  需注意次要条件 如:长度相同时,姓名内容,年龄等条件是否相等,这决定着是否存入TreeSet集合。

 

package cn.itcast.day21.treeset;
/*
 * 要实现自然排序,就一定要实现Comparable接口,并重写compareTo()方法
 * 
 * 若不实现Comparable接口,而把对象往TreeSet中添加,就会报ClassCastException
 *       原因:java.util.TreeMap.put(TreeMap.java:542) 
 *      Comparable<? super K> k = (Comparable<? super K>) key;//key=集合元素,被强行转换成接口类型 
 * 
 */
public class Student {
    private String name;
    private int age;
    
    public Student() {
        super();
    }
    public Student(String name, int age) {
        super();
        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  {
        int num=this.getName().length()-o.getName().length();
        int num2=num==0?this.getName().compareTo(o.getName()):num;
        int num3=num2==0?this.getAge()-o.getAge():num2;
        
        return num3;
    }
}

 

 

package cn.itcast.day21.treeset;

import java.util.TreeSet;

/*
 * TreeSet 按照自定义对象Student的姓名长度自然排序
 * 
 * 
 * 分析:
 *         A:实现自然排序,元素的类就要实现Comparable接口,并重写compareTo()方法
 *         B:主要条件 姓名长度
 *         C:次要条件  姓名内容,年龄
 */
public class TreeSetDemo {
    public static void main(String[] args) {
        //创建集合对象
        TreeSet<Student> ts=new TreeSet<Student>();
        //创建元素对象
        Student s1=new Student("linqingxia",27);
        Student s2=new Student("wuqilong",27);
        Student s3=new Student("wanglihong",34);
        Student s4=new Student("zhouxingchi",57);
        Student s5=new Student("linqingxia",28);
        Student s6=new Student("linqingxia",27);
        
        //添加集合元素
        ts.add(s1);
        ts.add(s2);
        ts.add(s3);
        ts.add(s4);
        ts.add(s5);
        ts.add(s6);
        
        //遍历集合 
        for(Student s:ts){
            System.out.println(s.getName()+"-----"+s.getAge());
        }
    }

}
/** 运行结果:
wuqilong-----27
linqingxia-----27
linqingxia-----28
wanglihong-----34
zhouxingchi-----57
*/
开始做,坚持做,重复做
相关文章
|
8月前
|
存储
蓝桥杯-1/14天-数位排序【继承Comparable接口实现排序】
蓝桥杯-1/14天-数位排序【继承Comparable接口实现排序】
|
存储 安全
集合框架系列(三)之 map双列集合
集合框架系列(三)之 map双列集合
|
存储 Java
Java集合学习3:Set集合-TreeSet
基于hashcode计算元素存放位置。 当存入元素的哈希码相同时,会调用equals进行确认,如果为true,则拒绝后者存入。
Java集合学习3:Set集合-TreeSet
利用Comparable接口实现对对象数组的排序
利用Comparable接口实现对对象数组的排序
利用Comparable接口实现对对象数组的排序
TreeSet的两种排序方式
示例: 示例公用类: public class MyDate { private int month; private int year; private int day; @Override public String toString() { return "MyDate{" + "month=" + month + ", year=" + year +
124 0
|
存储 Java 索引
Java中TreeSet集合、自然排序、比较器排序、成绩排序及不重复随机数案例
TreeSet集合、自然排序、比较器排序、成绩排序及不重复随机数案例的简单示例
204 0
|
存储 算法 Java
TreeSet类的排序问题
TreeSet支持两种排序方法:自然排序和定制排序。TreeSet默认采用自然排序。1、自然排序    TreeSet会调用集合元素的compareTo(Object obj)方法来比较元素之间大小关系,然后将集合元素按升序排列,这种方式就是自然排序。
1696 0
|
存储 Java 索引
【Java集合类】之TreeSet集合与Comparable/Comparator排序
【Java集合类】之TreeSet集合与Comparable/Comparator排序
160 0
Java集合相关学习——元素排序两大接口Comparable和Comparator的应用及区别
Java集合相关学习——元素排序两大接口Comparable和Comparator的应用及区别
Java集合相关学习——元素排序两大接口Comparable和Comparator的应用及区别
Comparable方法中的compareTo方法的返回值的正负 判断升序 还是 降序
Comparable方法中的compareTo方法的返回值的正负 判断升序 还是 降序
261 0