1. 程式人生 > >對List中每個物件元素按時間順序排序

對List中每個物件元素按時間順序排序

物件排序

工作中遇到一個問題:

    呼叫別人家的介面查詢資料庫,可是介面中查詢的結果並沒有對結果進行時間排序。於是就用了一下方法對查詢的結果集根據時間排序。我的專案中類結構複雜,我用簡單的使用者類來演示排序過程,更是希望能看的懂。

import java.text.SimpleDateFormat;
import java.util.*;

public class ListSort {
    public static class UserBean {
        private String id;
        private String birthday;

        public String getId() {
            return id;
        }

        public void setId(String id) {
            this.id = id;
        }

        public String getBirthday() {
            return birthday;
        }

        public void setBirthday(String birthday) {
            this.birthday = birthday;
        }
    }

    public static void main(String[] args) {
        List<UserBean> list = new ArrayList<UserBean>();
        UserListGenerate(list);
        System.out.println("排序前:"+list);

        ListSort(list);
        System.out.println("排序後:"+list);
    }

    private static void UserListGenerate(List<UserBean> list) {
        UserBean user1 = new UserBean();
        UserBean user2 = new UserBean();
        UserBean user3 = new UserBean();
        user1.setId("zhagnsan");
        user1.setBirthday("1980-11-01");

        user2.setId("lisi");
        user2.setBirthday("1981-12-01");

        user3.setId("wangwu");
        user3.setBirthday("1980-12-01");

        list.add(user1);
        list.add(user2);
        list.add(user3);
    }

    private static void ListSort(List<UserBean> list) {
        Collections.sort(list, new Comparator<UserBean>() {
            @Override
            public int compare(UserBean o1, UserBean o2) {
                SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
                try {
                    Date dt1 = format.parse(o1.getBirthday());
                    Date dt2 = format.parse(o2.getBirthday());
                    if (dt1.getTime() > dt2.getTime()) {
                        return 1;
                    } else if (dt1.getTime() < dt2.getTime()) {
                        return -1;
                    } else {
                        return 0;
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                }
                return 0;
            }
        });
    }
}

以上是根據物件中的時間對列表集合排序。

拓展

Comparator是個介面,可重寫compare()及equals()這兩個方法,用於比價功能;如果是null的話,就是使用元素的預設順序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f,g這樣,當然數字也是這樣的。
compare(a,b)方法:根據第一個引數小於、等於或大於第二個引數分別返回負整數、零或正整數。
equals(obj)方法:僅當指定的物件也是一個 Comparator,並且強行實施與此 Comparator 相同的排序時才返回 true。

Collections.sort(list, new PriceComparator());的第二個引數返回一個int型的值,就相當於一個標誌,告訴sort方法按什麼順序來對list進行排序。

具體實現程式碼方法如下:

Book實體類:

    package com.tjcyjd.comparator;  
      
    import java.text.DecimalFormat;  
    import java.text.SimpleDateFormat;  
    import java.util.GregorianCalendar;  
    import java.util.Iterator;  
    import java.util.TreeMap;  
      
    /** 
     * 書實體類 
     *  
     * @author yjd 
     *  
     */  
    public class Book implements Comparable { // 定義名為Book的類,預設繼承自Object類  
        public int id;// 編號  
        public String name;// 名稱  
        public double price; // 價格  
        private String author;// 作者  
        public GregorianCalendar calendar;// 出版日期  
      
        public Book() {  
            this(0, "X", 0.0, new GregorianCalendar(), "");  
        }  
      
        public Book(int id, String name, double price, GregorianCalendar calender,  
                String author) {  
            this.id = id;  
            this.name = name;  
            this.price = price;  
            this.calendar = calender;  
            this.author = author;  
        }  
      
        // 重寫繼承自父類Object的方法,滿足Book類資訊描述的要求  
        public String toString() {  
            String showStr = id + "\t" + name; // 定義顯示類資訊的字串  
            DecimalFormat formatPrice = new DecimalFormat("0.00");// 格式化價格到小數點後兩位  
            showStr += "\t" + formatPrice.format(price);// 格式化價格  
            showStr += "\t" + author;  
            SimpleDateFormat formatDate = new SimpleDateFormat("yyyy年MM月dd日");  
            showStr += "\t" + formatDate.format(calendar.getTime()); // 格式化時間  
            return showStr; // 返回類資訊字串  
        }  
      
        public int compareTo(Object obj) {// Comparable介面中的方法  
            Book b = (Book) obj;  
            return this.id - b.id; // 按書的id比較大小,用於預設排序  
        }  
      
        public static void main(String[] args) {  
            Book b1 = new Book(10000, "紅樓夢", 150.86, new GregorianCalendar(2009,  
                    01, 25), "曹雪芹、高鄂");  
            Book b2 = new Book(10001, "三國演義", 99.68, new GregorianCalendar(2008, 7,  
                    8), "羅貫中 ");  
            Book b3 = new Book(10002, "水滸傳", 100.8, new GregorianCalendar(2009, 6,  
                    28), "施耐庵 ");  
            Book b4 = new Book(10003, "西遊記", 120.8, new GregorianCalendar(2011, 6,  
                    8), "吳承恩");  
            Book b5 = new Book(10004, "天龍八部", 10.4, new GregorianCalendar(2011, 9,  
                    23), "搜狐");  
            TreeMap tm = new TreeMap();  
            tm.put(b1, new Integer(255));  
            tm.put(b2, new Integer(122));  
            tm.put(b3, new Integer(688));  
            tm.put(b4, new Integer(453));  
            tm.put(b5, new Integer(40));  
            Iterator it = tm.keySet().iterator();  
            Object key = null, value = null;  
            Book bb = null;  
            while (it.hasNext()) {  
                key = it.next();  
                bb = (Book) key;  
                value = tm.get(key);  
                System.out.println(bb.toString() + "\t庫存:" + tm.get(key));  
            }  
        }  
    }  

自定義比較器和測試類:
    package com.tjcyjd.comparator;  
      
    import java.util.ArrayList;  
    import java.util.Collections;  
    import java.util.Comparator;  
    import java.util.GregorianCalendar;  
    import java.util.Iterator;  
    import java.util.List;  
      
    public class UseComparator {  
        public static void main(String args[]) {  
            List<Book> list = new ArrayList<Book>(); // 陣列序列  
            Book b1 = new Book(10000, "紅樓夢", 150.86, new GregorianCalendar(2009,  
                    01, 25), "曹雪芹、高鄂");  
            Book b2 = new Book(10001, "三國演義", 99.68, new GregorianCalendar(2008, 7,  
                    8), "羅貫中 ");  
            Book b3 = new Book(10002, "水滸傳", 100.8, new GregorianCalendar(2009, 6,  
                    28), "施耐庵 ");  
            Book b4 = new Book(10003, "西遊記", 120.8, new GregorianCalendar(2011, 6,  
                    8), "吳承恩");  
            Book b5 = new Book(10004, "天龍八部", 10.4, new GregorianCalendar(2011, 9,  
                    23), "搜狐");  
            list.add(b1);  
            list.add(b2);  
            list.add(b3);  
            list.add(b4);  
            list.add(b5);  
            // Collections.sort(list); //沒有預設比較器,不能排序  
            System.out.println("陣列序列中的元素:");  
            myprint(list);  
            Collections.sort(list, new PriceComparator()); // 根據價格排序  
            System.out.println("按書的價格排序:");  
            myprint(list);  
            Collections.sort(list, new CalendarComparator()); // 根據時間排序  
            System.out.println("按書的出版時間排序:");  
            myprint(list);  
        }  
      
        // 自定義方法:分行列印輸出list中的元素  
        public static void myprint(List<Book> list) {  
            Iterator it = list.iterator(); // 得到迭代器,用於遍歷list中的所有元素  
            while (it.hasNext()) {// 如果迭代器中有元素,則返回true  
                System.out.println("\t" + it.next());// 顯示該元素  
            }  
        }  
      
        // 自定義比較器:按書的價格排序  
        static class PriceComparator implements Comparator {  
            public int compare(Object object1, Object object2) {// 實現介面中的方法  
                Book p1 = (Book) object1; // 強制轉換  
                Book p2 = (Book) object2;  
                return new Double(p1.price).compareTo(new Double(p2.price));  
            }  
        }  
      
        // 自定義比較器:按書出版時間來排序  
        static class CalendarComparator implements Comparator {  
            public int compare(Object object1, Object object2) {// 實現介面中的方法  
                Book p1 = (Book) object1; // 強制轉換  
                Book p2 = (Book) object2;  
                return p2.calendar.compareTo(p1.calendar);  
            }  
        }  
    }