java 自定义类比较器代码

java 自定义类比较器

示例:

package com.myfile;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

/**
 * Created by tengfei on 2017/10/27
 */
public class CompareTest {
  /**
   * 内部比较器:Comparable, 重写conpareTo方法
   */
  @SuppressWarnings("rawtypes")
  class Student1 implements Comparable {
    private String name;
    private int age;

    public Student1(int age, String name) {
      this.age = age;
      this.name = name;
    }

    @Override
    public String toString() {
      return "\tStudent1 age: " + age + ", name: " + name + "\r";
    }

    @Override
    public int compareTo(Object o) {
      Student1 tmp = (Student1) o;
      int result = tmp.age < age ? 1 : (tmp.age == age ? 0 : -1);
      return result = result == 0 ? (tmp.name.trim().compareTo(name.trim()) < 0 ? 1 : -1) : result;
    }
  }

  // -------------------------------------------------------------------------------------

  /**
   * 外部比较器:Comparator, 定义comparator比较类
   */
  class Student2 {
    private String name;
    private int age;

    public Student2(int age, String name) {
      this.age = age;
      this.name = name;
    }

    @Override
    public String toString() {
      return "\tStudent2 age: " + age + ", name: " + name + "\r";
    }
  }

  @SuppressWarnings("rawtypes")
  public static class Student2Comparator implements Comparator {
    public int compare(Object o1, Object o2) {
      Student2 t1 = (Student2) o1;
      Student2 t2 = (Student2) o2;
      int result = t1.age > t2.age ? 1 : (t1.age == t2.age ? 0 : -1);
      return result = result == 0 ? (t1.name.trim().compareTo(t2.name.trim()) > 0 ? 1 : -1) : result;
    }

    @SuppressWarnings("unchecked")
    public static void main(String[] args) {
      CompareTest co = new CompareTest();
      List<Student1> list1 = new ArrayList<Student1>();
      list1.add(co.new Student1(1, "aa"));
      list1.add(co.new Student1(2, "abb"));
      list1.add(co.new Student1(2, "acc"));
      list1.add(co.new Student1(3, "dd"));
      Collections.sort(list1); // 内部比较器:要排序的对象实现Comparable接口,可以对自身进行比较
      System.out.println(list1);

      List<Student2> list2 = new ArrayList<Student2>();
      list2.add(co.new Student2(1, "aa"));
      list2.add(co.new Student2(2, "abb"));
      list2.add(co.new Student2(2, "acc"));
      list2.add(co.new Student2(3, "dd"));
      Collections.sort(list2, new Student2Comparator()); // 外部比较器:通过实现Comparator接口
      System.out.println(list2);
    }
  }
}

补充知识:Comparator类中的compare(T o1,T o2)和compareTo()的使用与疑惑解答

这几天做项目刚好遇到需要排序的需求,大概就是你查询一个list,然后list中保存的是map数据,你需要根据map中的若干个数据排序,比如说

List<Map<String, Object>> list = new ArrayList<>();
Map<String, Object> yuan = new HashMap<>();
yuan.put("type", 7);
yuan.put("code", "c");
Map<String, Object> jia = new HashMap<>();
jia.put("type", 1);
jia.put("code", "b");
Map<String, Object> min = new HashMap<>();
min.put("type", 6);
min.put("code", "a");
Map<String, Object> min2 = new HashMap<>();
min2.put("type", 5);
min2.put("code", "d");
Map<String, Object> min3 = new HashMap<>();
min3.put("type", 8);
min3.put("code", "e");
Map<String, Object> min4 = new HashMap<>();
min4.put("type", 7);
min4.put("code", "h");
Map<String, Object> min5 = new HashMap<>();
min5.put("type", 7);
min5.put("code", "f");

System.out.println("tttttttttttttttt"+min5.get("type"));

list.add(min);//6 a
list.add(min2);//5 d
list.add(min3);//8 e
list.add(min4);//7 h
list.add(min5);//7 f
list.add(jia);//1 b
list.add(yuan);//7 c

这个里面我需要”先将type为7的优先排序置顶,然后剩下的根据code倒序排序“相信第一次碰到这个的朋友是一头雾水,但是compare和compareTo就能很好的解决这个问题。接下来你们先思考一下这个需求,要是你你会怎么做,接下来我会先将思路,然后顺带将这两个方法在其中的应用做一一解释。

思路:(相当于if-else的思路)如果两个比较的数据为7我们就将这两个数据根据code值排序,如果两个值一个是7一个是别的值,我们就将7排在这个值的前面,如果两个type都不是7,我们就优先比较type值,如果比较的是字符,那么compareTo比较的两个字符的acsII码

大概思路就是上面这个意思,然后我贴实现代码并把我开始学的时候迷茫的问题进行解答

1《compare(T o1, T o2)是中的o1,o2代表什么,是怎么实现排序的?怎么和compareTo()配合使用?

答:o1和o2每次只取一个数据,就一次只比较两个数据,假如比较7,8,9,5,6,那么第一次比较o1先取8,o2取7(很奇怪,我当时以为是顺着取值,但是很奇怪,他是相邻两个值逆着取值,但不管他,开心就好),接下来配合compareTo()实现这两个数的排序,o1.compareTo(o2)会返回一个int值,如果0说明o1和o2相等,如果返回负值,那么o1和o2会倒序排序,返回正值,那么o1和o2会正序排序。返回值之后这两个值就进行了排序,至此,这两个值已经排序好了,接下来第二次排序,o1取9,o2取8,第三次o1取5,o2取9.....

2《怎么进行多条件排序?

答:通过if进行条件筛选,看代码,下面我就将上面实现需求的代码实现,可以自己复制运行一下,有不懂的可以私信我

System.out.println(list);
 Collections.sort(list, new Comparator<Map<String, Object>>() {

  @Override
  public int compare(Map<String, Object> o1, Map<String, Object> o2) {
  System.out.println("o1="+o1);
  System.out.println("o2="+o2);//== null ? "" : o1.get("name").toString()
  String a = (o1.get("Tsype") == null ? "" : o1.get("TYspe").toString()).indexOf("7")+"";
  System.out.println("TYpe="+o1.get("type")+"   a="+a);
  String b = (o2.get("TYpe") == null ? "" : o2.get("TYpe").toString()).indexOf("7")+"";

  System.out.println("type="+o2.get("type")+"   b="+b);
  System.out.println();
  if (a.equals(b)) {
   System.out.println("o1.code="+o1.get("code"));
   System.out.println("o2.code="+o2.get("code"));
   System.out.println((o2.get("code")+"").compareTo(o1.get("code")+ ""));
   System.out.println("===============================================");
   return (o2.get("code")+"").compareTo(o1.get("code")+ "");
  }
  System.out.println( b.compareTo(a));
  System.out.println("---------------------------------------------------");
  return b.compareTo(a);
  }
 });
 System.out.println("最后显示的list="+list);
 }

开始学的时候多打一点syso,看一下规则,一点一点找规则,看一下大手子是怎么做的,哈哈,不懂下面私我

以上这篇java 自定义类比较器代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • java SpringBoot自定义注解,及自定义解析器实现对象自动注入操作

    # java-SpringBoot自定义参数解析器实现对象自动注入 解析器逻辑流程图表 后台解析注解的解析器 首先,我在java后台编写了一个解析器,代码如下 import com.ruoyi.framework.interceptor.annotation.LoginUser; import com.ruoyi.project.WebMoudle.WebUser.domain.WebUser; import com.ruoyi.project.WebMoudle.WebUser.service

  • Java自定义比较器实现中文排序

    compareTo 方法 compareTo()是两个字符串对象比较大小,返回一个整数值,如果调用字符串对象大,返回正整数,反之,返回负整数.相等则返回0.compareTo()是两个字符串对象按ASCII比较大小(汉字是Unicode),返回一个整数值,如果调用字符串对象大,返回正整数,反之,返回负整数.相等则返回0. Comparator 比较器 Java 内实现自定义比较器比较简单,实现Comparator接口的compare()这个方法来制定排序规则,按照Java规范应满足以下约定,否则

  • java自定义Scanner类似功能类的实例讲解

    读取键盘输入 package com.zjx.io; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; /** * 面试题 * 读取键盘各个数据类型 * */ public class TestFaceIo { public static void main(String[] args) { System.out.print("请输入姓名: "); S

  • java 实现Comparable接口排序,升序、降序、倒叙

    本人由于项目开发中需要对查询结果list进行排序,这里根据的是每一个对象中的创建时间降序排序.本人讲解不深,只实现目的,如需理解原理还需查阅更深的资料. 1.实现的效果 2.创建排序的对象 package com.practice.test.comparable; import java.util.Date; /** * 描述:要比较的对象 * * @author cui * @create 2018-12-18 14:07 */ public class MySortBean implemen

  • java 自定义类比较器代码

    java 自定义类比较器 示例: package com.myfile; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; /** * Created by tengfei on 2017/10/27 */ public class CompareTest { /** * 内部比较器:Comparable, 重写conpareT

  • java自定义类加载器代码示例

    如果要使用自定义类加载器加载class文件,就需要继承java.lang.ClassLoader类. ClassLoader有几个重要的方法: protectedClassLoader(ClassLoaderparent):使用指定的.用于委托操作的父类加载器创建新的类加载器. protectedfinalClass<?>defineClass(Stringname,byte[]b,intoff,intlen):将一个byte数组转换为Class类的实例. protectedClass<

  • 详解java自定义类

    引用数据类型(类) 引用数据类型分类 提到引用数据类型(类),其实我们对它并不陌生,之前使用过的Scanner类.Random类. 我们可以把类的类型为两种: 第一种,Java为我们提供好的类,如Scanner类,Random类等,这些已存在的类中包含了很多的方法与属性,可供我们使用. 第二种,我们自己创建的类,按照类的定义标准,可以在类中包含多个方法与属性,来供我们使用. 这里我们主要介绍第二种情况的简单使用. 自定义数据类型概述 我们在Java中,将现实生活中的事物抽象成了代码.这时,我们可

  • Java用20行代码实现抖音小视频批量转换为gif动态图

    本文主要介绍了Java用20行代码实现抖音小视频批量转换为gif动态图,分享给大家,具体如下: 效果图 本功能实现需要用到第三方jar包 jave,JAVE 是java调用FFmpeg的封装工具. spring boot项目pom文件中添加以下依赖 <!-- https://mvnrepository.com/artifact/ws.schild/jave-core --> <dependency> <groupId>ws.schild</groupId>

  • java自定义日期转化类示例

    java自定义日期转化类 复制代码 代码如下: import java.text.DateFormat;import java.text.ParseException;import java.text.SimpleDateFormat;import java.util.Date; import org.apache.commons.beanutils.Converter; /** * 自定义 java.util.Date日期转换器 *  *  */public class MyDateConve

  • java&javascript自定义加密数据传输代码示例

    在开发应用过程中,客户端与服务端经常需要进行数据传输,涉及到重要隐私信息时,开发者自然会想到对其进行加密,即使传输过程中被"有心人"截取,也不会将信息泄露.对于加密算法,相信不少开发者也有所耳闻,比如MD5加密,Base64加密,DES加密,AES加密,RSA加密等等..可利用亦或,并,且,等进行简单加密. 示例代码中使用的^运算key=0x01,可自定义自己的规则.定义自己的运算,保证可逆数据不丢失即可.key也可定义,动态key. java代码 public static Stri

  • java Scanner类的使用示例代码

    Scanner类简介 Java 5添加了java.util.Scanner类,这是一个用于扫描输入文本的新的实用程序.它是以前的StringTokenizer和Matcher类之间的某种结合.由于任何数据都必须通过同一模式的捕获组检索或通过使用一个索引来检索文本的各个部分.于是可以结合使用正则表达式和从输入流中检索特定类型数据项的方法.这样,除了能使用正则表达式之外,Scanner类还可以任意地对字符串和基本类型(如int和double)的数据进行分析.借助于Scanner,可以针对任何要处理的

  • Java如何自定义类数组的创建和初始化

    目录 自定义类数组的创建和初始化 自定义类封装数组,添加类方法实现数据 自定义类数组的创建和初始化 刚刚在慕课学习Java的集合类List过程中,向集合中添加元素时,遇到一个问题: 定义了一个Course类 public class Course { private String id; private String name; //课程名称 //get set方法 public String getId() { return id; } public void setId(String id)

随机推荐