日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java集合框架:Collections工具类

發布時間:2024/4/11 java 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java集合框架:Collections工具类 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

歡迎支持筆者新作:《深入理解Kafka:核心設計與實踐原理》和《RabbitMQ實戰指南》,同時歡迎關注筆者的微信公眾號:朱小廝的博客。


歡迎跳轉到本文的原文鏈接:https://honeypps.com/java/java-collection-collections/

java.util.Collections工具類提供很多有用的方法,使得程序猿操作集合類的時候更加的方便容易,這些方法都是靜態的。整個Collections工具類源碼差不多有4000行,我們針對一些典型的方法進行闡述。


1. 調用一個空List,Set,Map

public static final List EMPTY_LIST = new EmptyList<>(); public static final Map EMPTY_MAP = new EmptyMap<>(); public static final Set EMPTY_SET = new EmptySet<>();

2. addAll

public static <T> boolean addAll(Collection<? super T> c, T… elements):向指定的集合c中加入特定的一些元素elements
案例2-1:

List<String> list = new ArrayList<>();list.add("s2");list.add("s4");list.add("s1");list.add("s3");System.out.println(list);Collections.addAll(list, "s5","s7",null,"s9");System.out.println(list);

運行結果:

[s2, s4, s1, s3] [s2, s4, s1, s3, s5, s7, null, s9]

3. binarySearch

public static <T> int binarySearch(List<? extends Comparable<? super T>> list, T key)
public static <T> int binarySearch(List<? extends T> list, T key, Comparator<? super T> c)
利用二分法在指定的集合中查找元素,至于Comparable以及Comparator相信看過前面一些列博文的朋友應該很清楚了,具體的也可以參考《Comparable與Comparator淺析》


4. sort

public static <T extends Comparable<? super T>> void sort(List<T> list) 需要泛型T類本身支持Comparable接口
public static <T> void sort(List<T> list, Comparator<? super T> c)
具體舉例可以參考《Comparable與Comparator淺析》


5. shuffle

public static void shuffle(List<?> list)
public static void shuffle(List<?> list, Random rnd)
混排。混排算法所做的正好與sort相反:它打亂在一個List中可能有的任何排列的蹤跡。也就是說,基于隨機源的輸入重排list,這樣的排列具有相同的可能性(假設隨機源是公正的)。這個算法在實現一個碰運氣的Game中非常有用。
案例5-1:

public static void test3(){List<String> list = new ArrayList<>();list.add("s1");list.add("s2");list.add("s3");list.add("s4");Collections.shuffle(list);System.out.println(list);}

每次運行結果都不同。


6. 反轉

有關反轉主要有這三個方法:

  • public static void reverse(List<?> list)直接反轉集合的元素
  • public static <T> Comparator<T> reverseOrder();返回可以使集合反轉的比較器Comparator
  • public static <T> Comparator<T> reverseOrder(Comparator<T> cmp);如果cmp不為null,返回cmp的反轉的比較器,即集合的反轉的反轉,最后就是沒反轉。如果cmp為null,效果等同于第二個方法.
  • 舉幾個案例來說明下用法。
    案例6-1:

    List<String> list = new ArrayList<>();list.add("s1");list.add("s2");list.add("s3");list.add("s4");System.out.println(list);Collections.reverse(list);System.out.println(list);

    運行結果:

    [s1, s2, s3, s4] [s4, s3, s2, s1]

    案例6-2:

    List<String> list = new ArrayList<>();list.add("s1");list.add("s2");list.add("s3");System.out.println(list);Comparator<String> comp = Collections.reverseOrder();Collections.sort(list,comp);System.out.println(list);

    運行結果:(同上)
    案例6-3:

    List<String> list = new ArrayList<>();list.add("s1");list.add("s2");list.add("s3");list.add("s4");System.out.println(list);Comparator<String> comp = Collections.reverseOrder();Collections.sort(list,comp);System.out.println(list);Comparator<String> comp2 = Collections.reverseOrder(comp);Collections.sort(list,comp2);System.out.println(list);

    運行結果:

    [s1, s2, s3, s4] [s4, s3, s2, s1] [s1, s2, s3, s4]

    如果把Comparator<String> comp2 = Collections.reverseOrder(comp);改成Comparator<String> comp2 = Collections.reverseOrder(null);運行結果:

    [s1, s2, s3, s4] [s4, s3, s2, s1] [s4, s3, s2, s1]

    7.synchronized系列

    確保所封裝的集合線程安全(強同步)

  • public static <T> Collection<T> synchronizedCollection(Collection<T> c)
  • public static <T> SortedSet<T> synchronizedSortedSet(SortedSet<T> s)
  • public static <T> List<T> synchronizedList(List<T> list)
  • public static <K,V> Map<K,V> synchronizedMap(Map<K,V> m)
  • public static <K,V> SortedMap<K,V> synchronizedSortedMap(SortedMap<K,V> m)
  • public static <T> SortedSet<T> synchronizedSortedSet(SortedSet<T> s)

  • 8. unmodifiable系列

    確保所封裝的集合不能修改。

  • public static <T> Collection<T> unmodifiableCollection(Collection<? extends T> c)
  • public static <T> Set<T> unmodifiableSet(Set<? extends T> s)
  • public static <T> SortedSet<T> unmodifiableSortedSet(SortedSet<T> s)
  • public static <T> List<T> unmodifiableList(List<? extends T> list)
  • public static <K,V> Map<K,V> unmodifiableMap(Map<? extends K, ? extends V> m)
  • public static <K,V> SortedMap<K,V> unmodifiableSortedMap(SortedMap<K, ? extends V> m)

  • 9.其他

    Collections工具類的功能不止上面這些,還有諸如fill(), rotate(), max(), min()等方法,不可能一下子就能全部記住,使用的時候多查查API即可。

    參考資料:

  • 《Comparable與Comparator淺析》
  • 歡迎跳轉到本文的原文鏈接:https://honeypps.com/java/java-collection-collections/


    歡迎支持筆者新作:《深入理解Kafka:核心設計與實踐原理》和《RabbitMQ實戰指南》,同時歡迎關注筆者的微信公眾號:朱小廝的博客。


    總結

    以上是生活随笔為你收集整理的Java集合框架:Collections工具类的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。