Java使用Collections集合工具類

1、Collections 集合工具類

Java 中的 Collections 是一個非常有用的工具類,它提供了許多靜態方法來操作或返回集合。這個類位于 java.util 包中,主要包含對集合進行操作的方法,比如排序、搜索、線程安全化等。

Java集合工具類的使用:

《Java使用Collections集合工具類》

《Java使用CollectionUtils集合工具類》

Java中 的 Collections 工具類提供了豐富的靜態方法來操作集合,主要功能可分為以下幾類:

方法說明
一、排序操作
sort(List<T> list)對 List 進行自然排序(元素需實現 Comparable 接口)。
sort(List<T> list, Comparator<? super T> c)使用自定義比較器排序
reverse(List<?> list)反轉 List 元素順序。
shuffle(List<?> list)隨機打亂 List 元素順序。
swap(List<?> list, int i, int j)交換指定位置元素。
二、查找與統計
max(Collection<? extends T> coll)返回集合最大值。
min(Collection<? extends T> coll)返回集合最小值。
frequency(Collection<?> c, Object o)統計元素出現次數。
binarySearch(List<? extends Comparable<? super T>> list, T key)二分查找已排序列表。
三、新增與修改
addAll(Collection<? super T> c, T... elements)批量添加元素。
replaceAll(List<T> list, T oldVal, T newVal)替換所有匹配元素。
fill(List<? super T> list, T obj)用指定元素填充列表。
copy(List<? super T> dest, List<? extends T> src)列表復制。
四、不可變集合
unmodifiableCollection(Collection<? extends T> c)返回不可修改集合視圖。
unmodifiableList(List<? extends T> list)返回不可修改 List 視圖。
unmodifiableSet(Set<? extends T> s)返回不可修改 Set 視圖。
unmodifiableMap(Map<? extends K,? extends V> m)返回不可修改 Map 視圖。
五、同步控制
synchronizedCollection(Collection<T> c)返回線程安全集合。
synchronizedList(List<T> list)返回線程安全 List。
synchronizedSet(Set<T> s)返回線程安全 Set。
synchronizedMap(Map<K,V> m)返回線程安全 Map。
六、特殊集合
emptyList()、emptySet()、emptyMap()返回空集合不可變實例。
singletonList(T o)、singletonSet(T o)、singletonMap(K k, V v)返回單元素不可變集合。
nCopies(int n, T o)返回包含 n 個相同元素的不可變 List。
checkedCollection(Collection<E> c, Class<E> type)返回類型安全集合視圖。
七、其他方法
disjoint(Collection<?> c1, Collection<?> c2)判斷兩集合是否無交集。
indexOfSubList(List<?> source, List<?> target)返回子列表首次出現位置。
lastIndexOfSubList(List<?> source, List<?> target)返回子列表最后出現位置。
rotate(List<?> list, int distance)旋轉列表元素。

2、?Collections 方法的使用

Collections 類的方法都是靜態的,使用時直接通過類名調用,如 Collections.max(list)。這些方法大大簡化了集合操作,特別是對 List 的常見處理。?

【示例】使用?Collections 工具類提供的方法,模擬抽獎活動。

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;/*** 抽獎活動* @author pan_junbiao**/
public class CollectionsTest
{public static void main(String[] args){// 創建集合列表(獎池)List<Integer> jackpot = new ArrayList<>();// 獎池添加數據Collections.addAll(jackpot, 25, 100, 5, 60, 888, 90);System.out.println("獎池中的金額:" + jackpot);// 統計Integer maxPrize = Collections.max(jackpot);Integer minPrize = Collections.min(jackpot);System.out.println("獎池中的最大金額:" + maxPrize);System.out.println("獎池中的最小金額:" + minPrize);// 隨機打亂獎池順序Collections.shuffle(jackpot);System.out.println("抽獎結果:" + jackpot);}
}

執行結果:

?3、Collections 的排序方法

Collections 類的 sort() 方法、reverse()方法說明:

Collections.sort()方法:自然排序?:對 List 集合中的元素進行升序排列,要求元素必須實現 Comparable 接口(如String、Integer等已默認實現)。

Collections.reverse()方法:反轉 List 集合中元素的順序,不依賴元素是否可比較。

Collections 類提供了兩種 sort() 排序方法,分別如下:

(1)sort() 排序方法一:

public static <T extends Comparable<? super T>> void sort(List<T> list) 
{list.sort(null);
}

(2)sort() 排序方法二:

public static <T> void sort(List<T> list, Comparator<? super T> c) {list.sort(c);
}

該方法中指定比較方式 Comparator<? super T> c,即 c 必須實現 Comparator<? super T> 接口,重寫 compareTo() 方法指定比較項目。比較項目在類外指定,比較靈活。

【示例】使用 Collections 類的 sort() 方法、reverse()方法,實現對 List 列表進行排序與倒序。

/*** 使用 Collections 類的 sort() 方法、reverse()方法,* 實現對 List 列表進行排序與倒序。* @author pan_junbiao*/
@Test
public void testCollectionsSort()
{//創建列表(故意打亂順序)List<String> userList = new ArrayList<>();userList.add("pan_junbiao的博客_03");userList.add("pan_junbiao的博客_01");userList.add("pan_junbiao的博客_04");userList.add("pan_junbiao的博客_02");//執行排序方法(正序排序)Collections.sort(userList);System.out.println("正序排序:");userList.stream().forEach(System.out::println);//執行排序方法(倒序排序)Collections.reverse(userList);System.out.println("\n倒序排序:");userList.stream().forEach(System.out::println);
}

執行結果:

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/81867.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/81867.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/81867.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Unity基礎學習(五)Mono中的重要內容(1)延時函數

目錄 一、Mono中的延時函數Invoke 1. Invoke作用&#xff1a;延遲指定時間后執行一次函數。API&#xff1a; 2. InvokeRepeating作用&#xff1a;延遲后開始重復執行函數。API&#xff1a; 3. CancelInvoke作用&#xff1a;停止所有延時函數&#xff0c;或停止指定函數的延時…

180KHz 60V 5A開關電流升壓/升降壓型DC-DC轉換器XL4019升降壓芯片

介紹 XL6019是一款專為升壓、升降壓設計的 單片集成電路&#xff08;升壓和降壓是由外圍電路拓撲確定的&#xff09;&#xff0c;可工作在DC5V到40V輸入電 壓范圍&#xff0c;低紋波&#xff0c;內置功率MOS。XL6019內 置固定頻率振蕩器與頻率補償電路&#xff0c;簡化了電 路…

如何暢通需求收集渠道,獲取用戶反饋?

要暢通需求收集渠道、有效獲取用戶反饋&#xff0c;核心在于多樣化反饋入口、閉環反饋機制、用戶分層管理、反饋數據結構化分析等四個方面。其中&#xff0c;多樣化反饋入口至關重要&#xff0c;不同用戶有不同的溝通偏好&#xff0c;只有覆蓋多個反饋路徑&#xff0c;才能捕捉…

Python結合ollama和stramlit開發聊天機器人

Python結合ollama和stramlit開發聊天機器人 一、環境準備1、streamlit安裝2、langchain安裝3、ollama的安裝 二、Ollama平臺聊天機器人實現1、需求2、模型調用3、前端實現頁面呈現代碼實現 三、詳細代碼地址四、參考資源 一、環境準備 1、streamlit安裝 # 通過 pip 安裝 pip …

java jdbc執行Oracle sql文件

執行代碼 import java.io.FileInputStream; import java.io.InputStreamReader; import java.nio.charset.StandardCharsets; import java.sql.Connection; import java.sql.DriverManager;import org.apache.ibatis.jdbc.ScriptRunner;public class ExecSqlFileController {pu…

[Java實戰]Spring Boot整合MinIO:分布式文件存儲與管理實戰(三十)

[Java實戰]Spring Boot整合MinIO&#xff1a;分布式文件存儲與管理實戰&#xff08;三十&#xff09; 一、MinIO簡介與核心原理 MinIO 是一款高性能、開源的分布式對象存儲系統&#xff0c;兼容 Amazon S3 API&#xff0c;適用于存儲圖片、視頻、日志等非結構化數據。其核心特…

開發指南115-CSS中選擇器關系

1、選擇后代 可以用選擇器1 選擇器2&#xff08;中間用空格分隔&#xff09;來表達&#xff0c;也可以在大括號里通過包含關系來表達 舉例 .a .b 舉例.a { .b{} } 注意css本身并不支持嵌套的寫法&#xff0c;是scss等提供的擴展能力。 2、選擇直系后代 選擇器1 > 選擇器2&a…

創建型:抽象工廠模式

目錄 1、核心思想 2、實現方式 2.1 模式結構 2.2 實現案例 3、優缺點分析 4、適用場景 1、核心思想 目的&#xff1a;統一管理相關對象的創建&#xff0c;確保產品兼容性。優先用于需要強約束產品兼容性的場景&#xff08;如UI主題、跨平臺適配&#xff09; 概念&#…

乘最多水的容器 | 算法 | 給定一個整數數組。有n條垂線。找出其中的兩條線,使得它們與 x 軸共同構成的容器可以容納最多的水。

在我們日常生活中&#xff0c;蓄水似乎是一個極為樸素的物理行為&#xff1a;兩堵墻之間&#xff0c;注入水&#xff0c;看誰能裝得更多。可如果換個角度&#xff0c;從算法的視角去看這個問題&#xff0c;它會變得怎樣&#xff1f;你是否意識到&#xff0c;這樣一個簡單的問題…

無人機避障——深藍學院浙大Ego-Planner規劃部分

ESDF-free&#xff1a; 被這種類型的障礙物死死卡住的情況&#xff1a; 在一定范圍內建立ESDF&#xff1a; Ego-Planner框架&#xff1a; 找到{p,v} pair&#xff1a; 【注意】&#xff1a;首先根據在障礙物內航跡上的點Q&#xff0c;以及與它相鄰但不在障礙物內的兩個點&#…

零基礎設計模式——大綱匯總

零基礎學設計模式 - 大綱 前言 本教程旨在幫助零基礎的同學快速入門設計模式&#xff0c;理解其核心思想和應用場景。我們將通過清晰的講解和簡單的示例&#xff0c;逐步引導你掌握常用的設計模式。 第一部分&#xff1a;設計模式入門 什么是設計模式&#xff1f; 設計模式…

leetcode 92. Reverse Linked List II

題目描述 92. Reverse Linked List II 是第206題的進階版206. Reverse Linked List 思路很簡單&#xff0c;但一次性通過還是有點難度的。 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(n…

CUDA的設備,流處理器(Streams),核,線程塊(threadblock),線程,網格(?gridDim),塊(block)和多gpu設備同步數據概念

CUDA的設備,流處理器&#xff0c;核&#xff0c;線程塊&#xff08;threadblock&#xff09;&#xff0c;線程&#xff0c;網格&#xff08;?gridDim&#xff09;&#xff0c;塊&#xff08;block&#xff09;和多gpu設備同步數據概念 CUDA的設備,流處理器&#xff0c;核&…

spring5-配外部文件-spEL-工廠bean-FactoryBean-注解配bean

spring配外部文件 我們先在Spring里配置一個數據源 1.導c3p0包,這里我們先學一下hibernate持久化框架&#xff0c;以后用mybites. <dependency><groupId>org.hibernate</groupId><artifactId>hibernate-core</artifactId><version>5.2.…

Feature Toggle 不再亂:如何設計一個干凈、安全、可控的特性開關系統?

網羅開發 &#xff08;小紅書、快手、視頻號同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企業從事人工智能項目研發管理工作&#xff0c;平時熱衷于分享各種編程領域的軟硬技能知識以及前沿技術&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…

技術分享:大數據挖掘平臺架構設計與行業應用實踐

在數字化轉型浪潮下&#xff0c;企業數據規模呈指數級增長。如何構建高效的數據挖掘體系&#xff0c;實現數據價值變現&#xff0c;成為技術團隊面臨的重要課題。本文將深入探討大數據挖掘平臺的核心架構、關鍵技術及行業應用實踐。 一、平臺架構設計 1. 數據采集層 支持多源異…

計算機視覺與深度學習 | EMD-KPCA-LSTM、EMD-LSTM、LSTM回歸預測對比,多輸入單輸出(Matlab完整程序和數據)

以下是針對EMD-KPCA-LSTM、EMD-LSTM和LSTM回歸預測對比的完整可運行MATLAB實現。包含數據生成、特征處理、模型構建和性能評估全流程,并提供關鍵代碼注釋和注意事項。 完整代碼實現(含數據生成) %% 清理環境 clear; clc; close all; warning off;%% 生成模擬數據(正弦波+噪…

Axure應用交互設計:動態面板嵌套實現超強體驗感菜單表頭

親愛的小伙伴,在您瀏覽之前,煩請關注一下,在此深表感謝!如有幫助請訂閱專欄! Axure產品經理精品視頻課已登錄CSDN可點擊學習https://edu.csdn.net/course/detail/40420 課程主題:動態面板嵌套 主要內容:利用動態面板多層嵌套實現菜單表頭 應用場景:廣泛應用于表單表…

HarmonyOS 鴻蒙應用開發基礎:父組件和子組件的通信方法總結

在鴻蒙開發中&#xff0c;ArkUI聲明式UI框架提供了一種現代化、直觀的方式來構建用戶界面。然而&#xff0c;由于其聲明式的特性&#xff0c;父組件與子組件之間的通信方式與傳統的命令式框架有所不同。本文旨在詳細探討在ArkUI框架中&#xff0c;父組件和子組件通信的方法總結…

深度學習模塊縫合拼接方法套路+即插即用模塊分享

前言 在深度學習中&#xff0c;模型的設計往往不是從頭開始&#xff0c;而是通過組合不同的模塊來構建。這種“模塊縫合”技術&#xff0c;就像搭積木一樣&#xff0c;把不同的功能模塊拼在一起&#xff0c;形成一個強大的模型。今天&#xff0c;我們就來聊聊四種常見的模塊縫…