您好,登錄后才能下訂單哦!
小編給大家分享一下java如何實現(xiàn)Comparable接口排序,升序、降序、倒敘的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
1.實現(xiàn)的效果
2.創(chuàng)建排序的對象
package com.practice.test.comparable; import java.util.Date; /** * 描述:要比較的對象 * * @author cui * @create 2018-12-18 14:07 */ public class MySortBean implements Comparable<MySortBean> { private String name; private int age; private Date createTime; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public Date getCreateTime() { return createTime; } public void setCreateTime(Date createTime) { this.createTime = createTime; } // @Override // public int compareTo(MySortBean o) { // if (this.age>o.age){ // return -1; // }else if (this.age==o.age){ // return 0; // } // return 1; // } @Override public int compareTo(MySortBean o) { if (this.createTime.compareTo(o.getCreateTime())>0){ return -1; }else if (this.createTime.compareTo(o.getCreateTime())==0){ return 0; } return 1; } @Override public String toString() { return "MySortBean{" + "name='" + name + '\'' + ", age=" + age + '}'; } }
3.編寫test方法
package com.practice.test; import com.practice.test.comparable.MySortBean; import com.spring.testlist.util.DateUtil; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * 描述: * 測試比較器 * * @author cui * @create 2018-12-18 14:10 */ @RunWith(SpringJUnit4ClassRunner.class) public class TestCompare { @Test public void testComparable(){ MySortBean m1 = new MySortBean(); m1.setAge(1); m1.setCreateTime(DateUtil.parseDate("2019-01-21 16:13:18")); MySortBean m2 = new MySortBean(); m2.setAge(2); m2.setCreateTime(DateUtil.parseDate("2019-01-23 16:13:18")); MySortBean m3 = new MySortBean(); m3.setAge(3); m3.setCreateTime(DateUtil.parseDate("2019-01-22 16:13:18")); MySortBean m4 = new MySortBean(); m4.setAge(4); m4.setCreateTime(DateUtil.parseDate("2019-01-24 16:13:18")); MySortBean m5 = new MySortBean(); m5.setAge(5); m5.setCreateTime(DateUtil.parseDate("2019-01-25 16:13:18")); List<MySortBean> l = new ArrayList<>(5); l.add(m1); l.add(m2); l.add(m4); l.add(m5); l.add(m3); System.out.println("排序前:"); for (MySortBean i:l) { System.out.println(DateUtil.formatDate(i.getCreateTime(),"yyyy-MM-dd HH:mm:ss")); } /** * 自定義排序 * 直接return -1 倒敘排列,list順序顛倒輸出 * * if (o1.getAge()>o2.getAge()){ * return 1; * } * return -1; * 以上升序輸出 * * if (o1.getAge()>o2.getAge()){ * return -1; * } * return 1; * 以上降序輸出 * * */ /* Comparator<MySortBean> comparator = new Comparator<MySortBean>() { @Override public int compare(MySortBean o1,MySortBean o2) { if (o1.getAge()>o2.getAge()){ return -1; } return 1; } }; l.sort(comparator);*/ l.sort(MySortBean::compareTo); System.out.println("--------"); System.out.println("排序后:"); for (MySortBean i:l) { System.out.println(DateUtil.formatDate(i.getCreateTime(),"yyyy-MM-dd HH:mm:ss")); } } }
4.時間格式化工具類
package com.spring.testlist.util; import org.apache.commons.lang3.time.DateFormatUtils; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; /** * 日期工具類, 繼承org.apache.commons.lang.time.DateUtils類 * * @author cui * @create 2018-10-26 15:30 **/ public class DateUtil extends org.apache.commons.lang3.time.DateUtils{ private static String[] parsePatterns = { "yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", "yyyy-MM", "yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", "yyyy/MM", "yyyy.MM.dd", "yyyy.MM.dd HH:mm:ss", "yyyy.MM.dd HH:mm", "yyyy.MM"}; /** * 得到當前日期字符串 格式(yyyy-MM-dd) */ public static String getDate() { return getDate("yyyy-MM-dd"); } /** * 得到當前日期字符串 格式(yyyyMMdd) */ public static String getSizeDate() { return getDate("yyyyMMdd"); } /** * 得到當前日期字符串 格式(yyyy-MM-dd) pattern可以為:"yyyy-MM-dd" "HH:mm:ss" "E" */ public static String getDate(String pattern) { return DateFormatUtils.format(new Date(), pattern); } /** * 得到日期字符串 默認格式(yyyy-MM-dd) pattern可以為:"yyyy-MM-dd" "HH:mm:ss" "E" */ public static String formatDate(Date date, Object... pattern) { if (date == null) { return null; } String formatDate = null; if (pattern != null && pattern.length > 0) { formatDate = DateFormatUtils.format(date, pattern[0].toString()); } else { formatDate = DateFormatUtils.format(date, "yyyy-MM-dd"); } return formatDate; } /** * 得到日期時間字符串,轉換格式(yyyy-MM-dd HH:mm:ss) */ public static String formatDateTime(Date date) { return formatDate(date, "yyyy-MM-dd HH:mm:ss"); } /** * 得到當前時間字符串 格式(HH:mm:ss) */ public static String getTime() { return formatDate(new Date(), "HH:mm:ss"); } /** * 得到當前日期和時間字符串 格式(yyyy-MM-dd HH:mm:ss) */ public static String getDateTime() { return formatDate(new Date(), "yyyy-MM-dd HH:mm:ss"); } /** * 得到當前年份字符串 格式(yyyy) */ public static String getYear() { return formatDate(new Date(), "yyyy"); } /** * 得到當前月份字符串 格式(MM) */ public static String getMonth() { return formatDate(new Date(), "MM"); } /** * 得到當天字符串 格式(dd) */ public static String getDay() { return formatDate(new Date(), "dd"); } /** * 得到當前星期字符串 格式(E)星期幾 */ public static String getWeek() { return formatDate(new Date(), "E"); } /** * 日期型字符串轉化為日期 格式 * { "yyyy-MM-dd", "yyyy-MM-dd HH:mm:ss", "yyyy-MM-dd HH:mm", * "yyyy/MM/dd", "yyyy/MM/dd HH:mm:ss", "yyyy/MM/dd HH:mm", * "yyyy.MM.dd", "yyyy.MM.dd HH:mm:ss", "yyyy.MM.dd HH:mm" } */ public static Date parseDate(Object str) { if (str == null) { return null; } try { return parseDate(str.toString(), parsePatterns); } catch (ParseException e) { return null; } } /** * 獲取過去的天數(shù) * * @param date * @return */ public static long pastDays(Date date) { long t = System.currentTimeMillis()- date.getTime(); return t / (24 * 60 * 60 * 1000); } /** * 獲取過去的小時 * * @param date * @return */ public static long pastHour(Date date) { long t =System.currentTimeMillis() - date.getTime(); return t / (60 * 60 * 1000); } /** * 獲取過去的分鐘 * * @param date * @return */ public static long pastMinutes(Date date) { long t = System.currentTimeMillis() - date.getTime(); return t / (60 * 1000); } /** * 轉換為時間(天,時:分:秒.毫秒) * * @param timeMillis * @return */ public static String formatDateTime(long timeMillis) { long day = timeMillis / (24 * 60 * 60 * 1000); long hour = (timeMillis / (60 * 60 * 1000) - day * 24); long min = ((timeMillis / (60 * 1000)) - day * 24 * 60 - hour * 60); long s = (timeMillis / 1000 - day * 24 * 60 * 60 - hour * 60 * 60 - min * 60); long sss = (timeMillis - day * 24 * 60 * 60 * 1000 - hour * 60 * 60 * 1000 - min * 60 * 1000 - s * 1000); return (day > 0 ? day + "," : "") + hour + ":" + min + ":" + s + "." + sss; } /** * 獲取兩個日期之間的天數(shù) * * @param before * @param after * @return */ public static double getDistanceOfTwoDate(Date before, Date after) { long beforeTime = before.getTime(); long afterTime = after.getTime(); return (afterTime - beforeTime) / (1000 * 60 * 60 * 24); } public static String getFirstDayOfMonth() { SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); //獲取當前月第一天: Calendar c = Calendar.getInstance(); c.add(Calendar.MONTH, 0); c.set(Calendar.DAY_OF_MONTH, 1);//設置為1號,當前日期既為本月第一天 String first = format.format(c.getTime()); return first; } /** * @param args * @throws ParseException */ public static void main(String[] args) throws ParseException { // System.out.println(formatDate(parseDate("2010/3/6"))); // System.out.println(getDate("yyyy年MM月dd日 E")); // long time = new Date().getTime()-parseDate("2012-11-19").getTime(); // System.out.println(time/(24*60*60*1000)); String sizeDate = formatDate(new Date(),"yyyyMMdd"); System.out.println(sizeDate); } }
到此就結束了,具體的要實現(xiàn)什么排序,根據(jù)示例自己腦補擴展就好了,例子中備注也已經(jīng)標注。
在使用排序注意兩個坑
1.要排序的字段為空的異常處理
2.要排序的字段相等的異常處理
補充知識:Java中的自然排序和比較器排序
寫在前面的話:剛開始學習著兩者排序時我也是一頭霧水,雖然能寫出來但是稀里糊涂,幾時該用哪個排序一點想法都沒有,后來經(jīng)過研究這兩者的作用點不同,自然排序作用在實體類上,而比較器排序作用在裝實體類的集合上。
1、自然排序:java.lang.Comparable
Comparable 接口中只提供了一個方法: compareTo(Object obj) ,該方法的返回值是 int 。如果返回值為正數(shù),則表示當前對象(調(diào)用該方法的對象)比 obj 對象“大”;反之“小”;如果為零的話,則表示兩對象相等。
總結為一句話:實現(xiàn)Comparable,重寫 compareTo方法
案列:以TreeMap為例,默認的升序,可以重寫自然排序的方法改變原有排序
public static void testComparable(){ TreeMap<Car,Object> tmp = new TreeMap<Car,Object>(); tmp.put(new Car(4), "肆"); tmp.put(new Car(1), "壹"); tmp.put(new Car(5), "伍"); tmp.put(new Car(3), "三"); tmp.put(new Car(2), "貳"); System.out.println(tmp); //結果://{Car [price=5.0]=伍, Car [price=4.0]=肆, Car [price=3.0]=三, Car [price=2.0]=貳, Car [price=1.0]=壹} } //自定義TreeMap排序方法 自然排序 class Car implements Comparable<Car>{ private double price; public double getPrice() { return price; } public void setPrice(double price) { this.price = price; } public Car(int price) { super(); this.price = price; } @Override public int compareTo(Car o) { // TODO Auto-generated method stub if(this.price>o.getPrice()){ return -1;//大的往前排 }else if(this.price<o.getPrice()){ return 1;//小的往后排 }else{ return 0; } } @Override public String toString() { return "Car [price=" + price + "]"; }
2、比較器排序:java.util.Comparator
總結為一句話:實現(xiàn)Comparator 接口,重寫compare方法
public static void testComparator(){ //HashMap<Integer,Object> hm = new HashMap<Integer,Object>(); TreeMap<Integer,Object> tmp = new TreeMap<Integer,Object>(new MyComparatorBigtoSmall()); tmp.put(4, "肆"); tmp.put(1, "壹"); tmp.put(5, "伍"); tmp.put(3, "三"); tmp.put(2, "貳"); //System.out.println(tmp);//默認排序結果:{1=壹, 2=貳, 3=三, 4=肆, 5=伍} System.out.println(tmp);//修改為比較器排序(升序){5=伍, 4=肆, 3=三, 2=貳, 1=壹} } //自定義TreeMap排序方法 比較器排序 class MyComparatorBigtoSmall implements Comparator<Integer>{ @Override public int compare(Integer o1, Integer o2) { // TODO Auto-generated method stub return o2-o1; } }
以上是java如何實現(xiàn)Comparable接口排序,升序、降序、倒敘的方法的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。