文章詳情頁
java如何對不同的類對象進行排序
瀏覽:96日期:2023-11-01 18:59:08
問題描述
假設兩個類A,B有共同的屬性date,我要對兩個List<A>, List<B>, 按照date進行排序,怎么做比較好?
我知道的方法是寫一個基類,然后A和B繼承這個基類,然后再調用Collections.sort()排序.
請問有沒有更好的辦法,或者是使用反射寫一個類似的方法?亦或是有現成的庫可以使用?
問題解答
回答1:使用上面你說的是較好的方法,1.可以利用java本身提供的api減少了代碼量,2.上面的方式在代碼風格上也蠻好的。還有一種思路是將每A,B類的date提出來并與A,B對象本身建立關聯,比如實現一個類Index,Index中有兩個屬性,date和A,B類對象的引用或者id,每個A,B類對象關聯一個Index對象,然后對Index對象排序,然后通過id找到對應A或B的對象,同index對象一樣的順序,即排好序。
回答2:list.sort((l1,l2) -> l1.getDate().compareTo(l2.getDate()));回答3:
弄一個Base Class,A、B extends之
弄一個Interface,A、B implements之
弄一個List<Object>,然后sort之,Comparator里面需要強轉類型
弄一個Wrapper class,包裝A、B,然后放在List中,sort之
標簽:
java
相關文章:
1. mysql優化 - mysql 一張表如果不能確保字段列長度一致,是不是就不需要用到char。2. python - scrapy 如何組合2個不同頁面的數據,一并存儲3. javascript - 新浪微博網頁版的字數限制是怎么做的4. javascript - 用jsonp抓取qq音樂總是說回調函數沒有定義5. python2.7 - python 函數或者類 代碼的執行順序6. node.js - mysql如何通過knex查詢今天和七天內的匯總數據7. sublime可以用其他編譯器替換嗎?8. 使用python中的pandas求每個值占該列的比例9. python - 多態調用方法時卻顯示bound method...10. mysql 怎么做到update只更新一行數據?
排行榜
