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 {
/**
* 內(nèi)部比較器: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); // 內(nèi)部比較器:要排序的對象實(shí)現(xiàn)Comparable接口,可以對自身進(jìn)行比較
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()); // 外部比較器:通過實(shí)現(xiàn)Comparator接口
System.out.println(list2);
}
}
}
補(bǔ)充知識(shí):Comparator類中的compare(T o1,T o2)和compareTo()的使用與疑惑解答
這幾天做項(xiàng)目剛好遇到需要排序的需求,大概就是你查詢一個(gè)list,然后list中保存的是map數(shù)據(jù),你需要根據(jù)map中的若干個(gè)數(shù)據(jù)排序,比如說
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
這個(gè)里面我需要”先將type為7的優(yōu)先排序置頂,然后剩下的根據(jù)code倒序排序“相信第一次碰到這個(gè)的朋友是一頭霧水,但是compare和compareTo就能很好的解決這個(gè)問題。接下來你們先思考一下這個(gè)需求,要是你你會(huì)怎么做,接下來我會(huì)先將思路,然后順帶將這兩個(gè)方法在其中的應(yīng)用做一一解釋。
思路:(相當(dāng)于if-else的思路)如果兩個(gè)比較的數(shù)據(jù)為7我們就將這兩個(gè)數(shù)據(jù)根據(jù)code值排序,如果兩個(gè)值一個(gè)是7一個(gè)是別的值,我們就將7排在這個(gè)值的前面,如果兩個(gè)type都不是7,我們就優(yōu)先比較type值,如果比較的是字符,那么compareTo比較的兩個(gè)字符的acsII碼
大概思路就是上面這個(gè)意思,然后我貼實(shí)現(xiàn)代碼并把我開始學(xué)的時(shí)候迷茫的問題進(jìn)行解答
1《compare(T o1, T o2)是中的o1,o2代表什么,是怎么實(shí)現(xiàn)排序的?怎么和compareTo()配合使用?
答:o1和o2每次只取一個(gè)數(shù)據(jù),就一次只比較兩個(gè)數(shù)據(jù),假如比較7,8,9,5,6,那么第一次比較o1先取8,o2取7(很奇怪,我當(dāng)時(shí)以為是順著取值,但是很奇怪,他是相鄰兩個(gè)值逆著取值,但不管他,開心就好),接下來配合compareTo()實(shí)現(xiàn)這兩個(gè)數(shù)的排序,o1.compareTo(o2)會(huì)返回一個(gè)int值,如果0說明o1和o2相等,如果返回負(fù)值,那么o1和o2會(huì)倒序排序,返回正值,那么o1和o2會(huì)正序排序。返回值之后這兩個(gè)值就進(jìn)行了排序,至此,這兩個(gè)值已經(jīng)排序好了,接下來第二次排序,o1取9,o2取8,第三次o1取5,o2取9.....
2《怎么進(jìn)行多條件排序?
答:通過if進(jìn)行條件篩選,看代碼,下面我就將上面實(shí)現(xiàn)需求的代碼實(shí)現(xiàn),可以自己復(fù)制運(yùn)行一下,有不懂的可以私信我
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);
}
開始學(xué)的時(shí)候多打一點(diǎn)syso,看一下規(guī)則,一點(diǎn)一點(diǎn)找規(guī)則,看一下大手子是怎么做的,哈哈,不懂下面私我
以上這篇java 自定義類比較器代碼就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot整合阿里云OSS對象存儲(chǔ)服務(wù)的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot整合阿里云OSS對象存儲(chǔ)服務(wù)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
Spring boot 整合KAFKA消息隊(duì)列的示例
這篇文章主要介紹了Spring boot 整合 KAFKA 消息隊(duì)列的示例,幫助大家更好的理解和使用spring boot框架,感興趣的朋友可以了解下2020-10-10
微信js-sdk+JAVA實(shí)現(xiàn)“分享到朋友圈”和“發(fā)送給朋友”功能詳解
本文分享了微信js-sdk+JAVA實(shí)現(xiàn)“分享到朋友圈”和“發(fā)送給朋友”功能介紹,大家可以參考一下2018-03-03
關(guān)于java開發(fā)的性能問題總結(jié)(必看)
下面小編就為大家?guī)硪黄P(guān)于java開發(fā)的性能問題總結(jié)(必看)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03
Java中ArrayBlockingQueue和LinkedBlockingQueue
這篇文章主要介紹了Java中ArrayBlockingQueue和LinkedBlockingQueue,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-09-09
SpringBoot使用Atomikos技術(shù)整合多數(shù)據(jù)源的實(shí)現(xiàn)
這篇文章主要介紹了SpringBoot使用Atomikos技術(shù)整合多數(shù)據(jù)源的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
SpringBoot框架RESTful接口設(shè)置跨域允許
這篇文章主要為大家詳細(xì)介紹了SpringBoot框架RESTful接口設(shè)置跨域允許,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08

