亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

java 自定義類比較器代碼

瀏覽:24日期:2022-08-26 13:39:26

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 alist.add(min2);//5 dlist.add(min3);//8 elist.add(min4);//7 hlist.add(min5);//7 flist.add(jia);//1 blist.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 自定義類比較器代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 玖玖国产在线观看 | 久热这里只精品99re8久 | 一级中国乱子伦视频 | 国产网站免费 | 婷婷色中文字幕 | 在线视频 一区二区 | 精品国产免费第一区二区 | 2019国内精品久久久久久 | 人成免费 | 成人午夜在线播放 | 国产区在线视频 | 国产午夜亚洲精品久久www | 91在线 在线播放 | 深夜国产| 可以直接看的毛片 | 欧美日韩亚洲国产一区二区综合 | 一区二区网站在线观看 | 网站在线观看高清免费 | 欧美变态口味重另类日韩毛片 | 操日韩美女 | 午夜精品视频在线看 | 久久国产精品自线拍免费 | 在线观看免费黄视频 | 成年男女免费视频观看性 | 亚洲黄色一级毛片 | 日本不卡高清中文字幕免费 | 久久精品免看国产 | 尤物在线 | 99热在线获取最新地址 | 亚洲网址| 国内拍拍自拍视频在线观看 | 在线亚洲欧美日韩 | 8x8x国产| 亚洲精品不卡在线 | 中日韩欧美中文字幕毛片 | 泄欲网站免费观看 | 一区二区三区四区亚洲 | 婷婷色婷婷 | 911精品国产91久久久久 | 精品一区二区国语对白 | 久青草国产手机在线观 |