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

java如何對不同的類對象進行排序

瀏覽:89日期: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
相關文章:
国产综合久久一区二区三区