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 自定义类比较器代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持自学编程网。
- 本文固定链接: https://zxbcw.cn/post/193827/
- 转载请注明:必须在正文中标注并保留原文链接
- QQ群: PHP高手阵营官方总群(344148542)
- QQ群: Yii2.0开发(304864863)