java 集合存儲對象且根據對象屬性排序
阿新 • • 發佈:2018-07-14
def xtra friend object actor seo 基本 () 相等
方法一:根據java1.8lambda表達式進行排序
Comparator<RateInfo> comparator = (t1, t2) -> t1.getRateCode().compareTo(t2.getRateCode());
方法二:使用List的方法sort()排序
List API:default void
sort(Comparator<? super E> c)
其實也是依據Comarator這個類
rateInfolist.sort(comparator.reversed());
方法三:使用Collections類的sort進行排序
static <T> void
sort(List<T> list, Comparator<? super T> c)
Comparator
類進行排序
Comparator
類API:英文翻譯即可
int compare(T o1, T o2) Compares its two arguments for order.static <T,U extends Comparable<? super U>> Comparator<T> comparing(Function<? super T,? extends U> keyExtractor) Accepts a function that extracts a Comparable sort key from a type T, and returns a Comparator<T> that compares by that sort key. static <T,U> Comparator<T> comparing(Function<? superT,? extends U> keyExtractor, Comparator<? super U> keyComparator) Accepts a function that extracts a sort key from a type T, and returns a Comparator<T> that compares by that sort key using the specified Comparator. static <T> Comparator<T> comparingDouble(ToDoubleFunction<? super T> keyExtractor) Accepts a function that extracts a double sort key from a type T, and returns a Comparator<T> that compares by that sort key. static <T> Comparator<T> comparingInt(ToIntFunction<? super T> keyExtractor) Accepts a function that extracts an int sort key from a type T, and returns a Comparator<T> that compares by that sort key. static <T> Comparator<T> comparingLong(ToLongFunction<? super T> keyExtractor) Accepts a function that extracts a long sort key from a type T, and returns a Comparator<T> that compares by that sort key. boolean equals(Object obj) Indicates whether some other object is "equal to" this comparator. static <T extends Comparable<? super T>> Comparator<T> naturalOrder() Returns a comparator that compares Comparable objects in natural order. static <T> Comparator<T> nullsFirst(Comparator<? super T> comparator) Returns a null-friendly comparator that considers null to be less than non-null. static <T> Comparator<T> nullsLast(Comparator<? super T> comparator) Returns a null-friendly comparator that considers null to be greater than non-null. default Comparator<T> reversed() Returns a comparator that imposes the reverse ordering of this comparator. static <T extends Comparable<? super T>> Comparator<T> reverseOrder() Returns a comparator that imposes the reverse of the natural ordering. default Comparator<T> thenComparing(Comparator<? super T> other) Returns a lexicographic-order comparator with another comparator. default <U extends Comparable<? super U>> Comparator<T> thenComparing(Function<? super T,? extends U> keyExtractor) Returns a lexicographic-order comparator with a function that extracts a Comparable sort key. default <U> Comparator<T> thenComparing(Function<? super T,? extends U> keyExtractor, Comparator<? super U> keyComparator) Returns a lexicographic-order comparator with a function that extracts a key to be compared with the given Comparator. default Comparator<T> thenComparingDouble(ToDoubleFunction<? super T> keyExtractor) Returns a lexicographic-order comparator with a function that extracts a double sort key. default Comparator<T> thenComparingInt(ToIntFunction<? super T> keyExtractor) Returns a lexicographic-order comparator with a function that extracts a int sort key. default Comparator<T> thenComparingLong(ToLongFunction<? super T> keyExtractor) Returns a lexicographic-order comparator with a function that extracts a long sort key.
代碼:
Collections.sort(rateInfolist, Comparator.comparing(RateInfo::getRateCode));
方法四:使用Comparator的匿名對象類重寫compare方法
代碼:
Collections.sort(rateInfolist, new Comparator<RateInfo>(){ /* * int compare(RateInfo R1, RateInfo R2) 返回一個基本類型的整型, * 返回負數表示:R1 小於R2, * 返回0 表示:R1和R2相等, * 返回正數表示:R1大於R2 */ public int compare(RateInfo R1, RateInfo R2) { Integer rateCode1 = Integer.parseInt(R1.getRateCode()); Integer rateCode2 = Integer.parseInt(R2.getRateCode()); //按照RateCode的年齡進行升序排列 if(rateCode1 > rateCode2){ return 1; } if(rateCode1 == rateCode2){ return 0; } return -1; } });
自己寫代碼時遇到的問題,根據我的理解和網上的資料做的總結
java 集合存儲對象且根據對象屬性排序