代码:

 1 import java.util.*;
2
3 /**
4 * 学习自定义排序:继承Comparable接口,重写compareTo方法(排序规则)。
5 * TreeMap容器的Key是自动排序的,Key为自定义类时,必须重写排序规则。
6 * Iterator迭代器遍历Map容器
7 */
8 public class DiySort {
9
10 /**
11 * 测试
12 * @param args
13 */
14 public static void main(String[] args) {
15 Temp t1 = new Temp(55,3.1,"第一个对象");
16 Temp t2 = new Temp(22,3.7,"第二个对象");
17 Temp t3 = new Temp(11,3.3,"第三个对象");
18 Temp t4 = new Temp(22,3.9,"第四个对象");
19 Temp [] ts = {t1,t2,t3,t4};
20 Arrays.sort(ts);
21 System.out.println("看看Arrays帮我排的序:");
22 System.out.println(Arrays.toString(ts));
23
24 //TreeMap容器的Key是自动排序的
25 TreeMap<Temp,String> tm1 = new TreeMap<>();
26 tm1.put(t1,"值1");
27 tm1.put(t2,"值2");
28 tm1.put(t3,"值3");
29 tm1.put(t4,"值4");
30 System.out.println("看看TreeMap里面的样子:");
31
32 //Iterator迭代器遍历容器,hasNext()判断此节点是否为空,next()返回此节点并且指向下一个节点。
33 Set<Map.Entry<Temp,String>> ss = tm1.entrySet();
34 for(Iterator<Map.Entry<Temp,String>> itr = ss.iterator(); itr.hasNext();){
35 Map.Entry<Temp,String> temp = itr.next();
36 System.out.println("Key:"+temp.getKey()+"value"+temp.getValue());
37 }
38 }
39 }
40
41 /**
42 * 某个类作为key值时,需要继承Comparable接口,重写compareTo方法(排序规则)。
43 */
44 class Temp implements Comparable<Temp>{
45 int i;
46 double d;
47 String str;
48
49 /**
50 * 此类的排序规则,
51 * @param o
52 * @return 1为大于传进来的数,0为相等,-1为小于
53 */
54 @Override
55 public int compareTo(Temp o) {
56 if(this.i>o.i){//先看i的值大小
57 return 1;
58 } else if(this.i==o.i){
59 if(this.d>o.d){//i的值相等时,看d的值大小
60 return 1;
61 }else if(this.d==o.d){
62 return 0;
63 }else {
64 return -1;
65 }
66 }else {
67 return -1;
68 }
69 }
70
71 /**
72 * 构造器
73 */
74 public Temp(int i, double d, String str) {
75 this.i = i;
76 this.d = d;
77 this.str = str;
78 }
79
80 @Override
81 public String toString() {
82 return "Temp{" +
83 "i=" + i +
84 ", d=" + d +
85 ", str='" + str + '\'' +
86 '}';
87 }
88 }

运行结果:

Java自定义排序:继承Comparable接口,重写compareTo方法(排序规则)的更多相关文章

  1. TreeSet集合的自然排序与比较器排序、Comparable接口的compareTo()方法

    [自然排序] package com.hxl; public class Student implements Comparable<Student> { private String n ...

  2. java 集合框架(TreeSet操作,自动对数据进行排序,重写CompareTo方法)

    /*TreeSet * treeSet存入数据后自动调用元素的compareTo(Object obj) 方法,自动对数据进行排序 * 所以输出的数据是经过排序的数据 * 注:compareTo方法返 ...

  3. 继承Comparable接口来实现排序

    1.java代码里进行排序(若sql能排序,就不要用代码排序) 可以继承Comparable接口来实现,若是在类中,可以声明Comparator对象,来进行比较 List<Map> map ...

  4. TreeSet——实现Comparable接口并重写CompareTo()方法

    TreeSet是以自然顺序存的数据,例如 Set<Student> students=new TreeSet(); students.add(new Student("111&q ...

  5. TreeMap——实现comparable接口并重写CompareTo方法

    public class TreeMapTest { public static void main(String[] args) { Map<Student,Integer> stude ...

  6. Effective Java 【考虑实现Comparable接口】

    Effective Java --Comparable接口 compareTo方法是Comparable接口的唯一方法.类实现了Comparable接口,表明它的实例具有内在的排序关系. 自己实现co ...

  7. 向集合中添加自定义类型--建议在自定义类型的时候要重写equals方法

    package com.bjpowernode.t01list; import java.util.ArrayList; /* * 向集合中添加自定义类型 */public class TestLis ...

  8. Swing自定义JScrollPane的滚动条设置,重写BasicScrollBarUI方法

    Swing自定义JScrollPane的滚动条设置,重写BasicScrollBarUI方法 摘自:https://blog.csdn.net/qq_31635851/article/details/ ...

  9. 通过实现System.IComparable接口的CompareTo方法对两个类进行比较

    假设现在有一个学生类 class Student { int age; public Student(int age) { this.age = age; } } 要使学生类之间能进行比较,实现Sys ...

随机推荐

  1. 【三维地图】开发攻略 —— 详解“GeoJSON”技术和应用场景

    GeoJSON ,一个用于存储地理信息的数据格式.GoeJSON对象可以表示几何.特征或特征集合,支持:点.线.面.多点.多线.多面和几何集合.在基于平面地图,三维地图中都需要用到的一种数据类型. 由 ...

  2. 【IDEA】IDEA打开欢迎页面

    概述 IDEA在默认情况下,会进入最后一个项目.如果项目比较大的话会加载的比较久,这个就比较烦人了,目前我觉得最好的办法就是在设置中直接进入欢迎页面. 解决方案 ① 进入设置 ② Appearance ...

  3. AtCoder Beginner Contest 255(E-F)

    Aising Programming Contest 2022(AtCoder Beginner Contest 255) - AtCoder E - Lucky Numbers 题意: 给两个数组a ...

  4. CF Workers反向代理并修改请求

    用于访问被墙的api请求 async function handleRequest(event) { const request = event.request const host = " ...

  5. KingbaseES R6 集群通过备库clone在线添加新节点

    案例说明: KingbaseES R6集群可以通过图形化方式在线添加新节点,但是在添加新节点clone环节时,是从主库copy数据到新的节点,这样在生产环境,如果数据量大,将会对主库的网络I/O造成压 ...

  6. 生信云实证Vol.12:王者带飞LeDock!开箱即用&一键定位分子库+全流程自动化,3.5小时完成20万分子对接

    LeDock是苏黎世大学Zhao HongTao在博士期间开发的一款分子对接软件,专为快速准确地将小分子灵活对接到蛋白质而设计.LeDock优于大部分商业软件,在Astex多样性集合上实现了大于90% ...

  7. Coprime

    Coprime 前置芝士 莫比乌斯反演 正文 首先,我们来分析题意. 题目中给出 \(n\) 个人,每个人有一个编号 \(k\) ,要求我们从中选出 \(3\) 个人,三人编号分别为 \(k_a\) ...

  8. 发布日志 - kratos v2.1.0 版本发布

    github https://github.com/go-kratos/kratos/releases/tag/v2.1.0 新的功能 新增客户端负载均衡器(load balancing)和路由选择器 ...

  9. ProxySQL(4):多层配置系统

    文章转载自:https://www.cnblogs.com/f-ck-need-u/p/9280793.html ProxySQL中的库 使用ProxySQL的Admin管理接口连上ProxySQL, ...

  10. 使用kubeoperator自带的nginx-ingress-controller设置服务的ingress规则进行访问

    情况说明 当使用kubeoperator安装k8s集群的时候,在组件设置部分选择的ingress 类型是nginx-ingress yaml文件 k8s集群安装后,可以在节点的master主机的这个目 ...