Java容器的各種總結

来源:http://www.cnblogs.com/shirenfeigui/archive/2017/04/16/6702715.html
-Advertisement-
Play Games

Java容器指的是List,Set,Map這些類。由於翻譯的問題,問到集合,Collection這些指的都是它們幾個。 List ArrayList 隨機訪問快 LinkedList 插入刪除快 這個好理解,array嘛就是數組,隨機訪問快。link嘛就是鏈表,當然是插入刪除快了。 Set 每個元素 ...


Java容器指的是List,Set,Map這些類。由於翻譯的問題,問到集合,Collection這些指的都是它們幾個。

List

ArrayList 隨機訪問快

LinkedList 插入刪除快

這個好理解,array嘛就是數組,隨機訪問快。link嘛就是鏈表,當然是插入刪除快了。

 

Set 每個元素只能放一次

HashSet 使用散列

TreeSet 使用紅黑樹,會對元素排序,介面是SortedSet。初始化TreeSet時可以傳入Comparator對象的實現做為排序函數

LinkedHashSet 也使用散列,但使用鏈表來維護插入順序

Set的訪問順序

HashSet按照HashCode的順序

TreeSet對元素排序有兩種方法:1、對象implements Comparable。2、new TreeSet傳入參數T extends Comparator。

   易錯點:兩個不要搞反了。在創建TreeSet的時候可以不初始化任何排序方法,此時不會報錯。但添加對象進去的時候就會報錯了,提示cannot be cast to java.lang.Comparable

LinkedHashSet按照插入的次序顯示

關於HashCode

HashCode是一個int數值,同一個對象要求在get和put的HashCode是同一個。不同對象的HashCode不要求必須不同,只要equals方法能區分開就可以了。

一個實用的HashCode應該是基於對象內容的,並且分佈平均的

 

Map相同的key只能放一次。這個key使用key對象的equals來判斷是否重覆

HashMap 類似HashSet,按key的HashCode存放

LinkedHashMap 可以按照插入次序存放,或者最近最少使用LRU順序存放。比HashMap慢一點,但迭代訪問時更快

TreeMap 類似TreeSet,基於紅黑樹排序

此外還有WeakHashMap, ConcurrentHashMap, IdentityHashMap

 

各種容器的遍歷

List<Integer> list = new ArrayList<Integer>();
        //使用Iterator遍歷。缺點是不能隨機訪問
        Iterator iter = list.iterator();
        while(iter.hasNext())
        {
            Integer i = (Integer) iter.next();
        }
        //這個比較好。不過註意調用get(i)的時候千萬不要超出List的長度範圍,尤其是進行刪除操作之後!
        for(int i=0; i<list.size(); i++)
        {
            Integer n = list.get(i);
        }
        for(Integer i : list)
        {
            //可以直接對i操作
        }
        //java8的forEach和lambda表達式組合是最牛的。適合遍歷輸入或者操作。
        list.forEach(s -> System.out.println(s));

 

HashSet<Integer> iset = new HashSet<Integer>();
        iset.add(3);
        iset.add(8);
        iset.add(7);
        iset.add(11);
        //最簡單的必須是它
        iset.forEach(i -> System.out.println(i));
        //不能用for了,因為沒有隨機訪問的get函數啦!
        Iterator<Integer> iter = iset.iterator();
        while(iter.hasNext())
        {
            iter.next();
        }
Map<String, String> map = new HashMap<String, String>();
        map.put("111", "one");
        map.put("zz", "zzzzzzzz");
        map.put("a", "apple");
        
        //對於entrySet迭代
        Iterator iter = map.entrySet().iterator();
        while(iter.hasNext())
        {
            Entry entry = (Entry) iter.next();
            System.out.println(entry.getKey() + ": " + entry.getValue());
        }
        
        //對key的set迭代
        Iterator iter2 = map.keySet().iterator();
        while(iter2.hasNext())
        {
            String key = (String) iter2.next();
            System.out.println(key + ": " + map.get(key));
        }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 支付基本上是很多產品都必須的一個模塊,大家最熟悉的應該就是微信和支付寶支付了,不過更多的可能還是停留在直接sdk的調用上,甚至和業務系統高度耦合,網上也存在各種解決方案,但大多形式各異,東拼西湊而成。所以這裡我介紹下OSS.PayCenter開源跨平臺支付組件 及其框架設計。並對常用支付模式進行一個 ...
  • 小分享:我有幾張阿裡雲優惠券,用券購買或者升級阿裡雲相應產品最多可以優惠五折!領券地址:https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=ohmepe03 目錄索引 【無私分享:ASP.NET COR ...
  • 小分享:我有幾張阿裡雲優惠券,用券購買或者升級阿裡雲相應產品最多可以優惠五折!領券地址:https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=ohmepe03 AppBox 是基於 FineUI 的通用權 ...
  • 小分享:我有幾張阿裡雲優惠券,用券購買或者升級阿裡雲相應產品最多可以優惠五折!領券地址:https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=ohmepe03 前言 今天給大家介紹一下在 ASP.NET ...
  • 背景 去年年底接到的新需求,需要將原來用Swing做的桌面應用中的一個功能做成Web版的,並且要集成到原應用中,換言之就是要使用內嵌瀏覽器。最開始考慮的是JavaFx提供的WebView,優點是不需要其他第三方庫,jdk1.7開始集成。但是開發完成之後發現兩個比較嚴重的問題,一是界面有一個比較複雜的 ...
  • 後續要做個日誌相關的東西,先筆記一下。 slf4j是日誌框架的一個門面端,背後實現者有log4j,logback等等。 如何實現這個門面的呢? 一般我們使用的代碼如下: slf4j 的LoggerFactory具體實現了門面模式中對接各種實現的事情。 getILoggerFactory方法: 上面, ...
  • 1、在創建之初,可以選擇自己想要使用的python版本。 如果之後想要更換Python版本,可以通過~~~更換選擇Python版本。 2、創建.py文件,點擊文件名,出現如下界面: 點擊new--python_file,就可以成功創建.py文件。 3、因為我的這一版pycharm死活找不到file- ...
  • 工廠模式(Factory pattern)和單例模式一樣,是另外一種創建型模式。和單例模式不同的是,單例模式會創建和管理一個單獨的類型的單一對象,工廠模式則是用於創建多種不同類型的類的多個對象。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...