走進Java中的持有對象(容器類)之一 容器分類

来源:http://www.cnblogs.com/ACFLOOD/archive/2016/06/03/5555555.html
-Advertisement-
Play Games

Java容器可以說是增強程式員編程能力的基本工具,本系列將帶您深入理解容器類。 容器的用途 如果對象的數量與生命周期都是固定的,自然我們也就不需要很複雜的數據結構。 我們可以通過創建引用來持有對象,如 也可以通過數組來持有多個對象,如 然而,一般情況下,我們並不知道要創建多少對象,或者以何種方式創建 ...


Java容器可以說是增強程式員編程能力的基本工具,本系列將帶您深入理解容器類。

  1. 容器的用途

如果對象的數量與生命周期都是固定的,自然我們也就不需要很複雜的數據結構。

我們可以通過創建引用來持有對象,如

Class clazz;

也可以通過數組來持有多個對象,如

Class[] clazs = new Class[10];

然而,一般情況下,我們並不知道要創建多少對象,或者以何種方式創建對象。數組顯然只能創建固定長度的對象,為了使程式變得更加靈活與高效,Java類庫提供了一套完整的容器類,具備完善的方法來解決上述問題。

 

    2.  容器的類別

 

觀察上圖,我們可以得出容器主要分為兩種類型,兩個介面Collection與Map定義了兩類不同的對象存儲方式。

Collection用以保存單一的元素,Map保存關聯鍵值對。通過泛型來指定容器存放的數據類型。 Iterator 設計的目的是在未知容器具體的類型的情況下,用來遍歷容器元素。剩下的容器類型都是繼承了這兩個介面。

在實際編碼中,通過向上轉型為介面,在其與代碼中都使用這個介面是非常普遍的使用方式。如下:

 

import java.util.*;

public class TestCollection {

    public static void main(String[] args){

        Collection<Integer> c = new ArrayList<Integer>();

        for(int i = 0; i < 10; i++){

            c.add(i);    

        }

        for(Integer i : c){

            System.out.print(i + ", ");

        }

    }

}

 

 

註:由於List介面的方法比Collection更為豐富,所以 實際應用中,ArrayList向上轉型為List更為合適。

剛剛接觸容器的朋友們可能會只把Collection與Map當做介面,實際上並非如此,容器中的介面其實有六個。

     

    3.  容器中的七大介面

  1. Collection介面
  2. Map介面
  3. Set介面
  4. List介面
  5. Queue介面
  6. Iterator介面
  7. Comparable介面

其中List, Queue和Set介面繼承了Collection介面,剩下的介面之間都是相互獨立的,無繼承關係。List和Set介面主要是為了區分是否要包含重覆元素,Iterater迭代器則是為了更靈活的迭代集合,與foreach一起使用。Comparable介面則用於比較。

 

    4.  各類容器的功能(主要實現類分析)

  • Collection介面
    • List介面(相比Collection, 添加了新的方法)
      • ArrayList

                    實現List介面,類似於動態數組,適用於大量隨機訪問的情況。但插入和刪除的代價非常高昂

  • LinkedList

                          實現List介面,類似於鏈表,也提供了優化的順序訪問。在插入和刪除方面代價低廉,隨機訪問代價較高

  • Set介面(方法與Collection完全相同)
    • HashSet

                        HashSet使用了散列函數實現,極大的提高了訪問速度。存入HashSet的對象必須定義hashCode()

 

import java.util.*;

public class IntegerSet{

  private static Random rand;

   public static void main(String[] args){

     rand = new Random(47);

      Set<Integer> intset = new HashSet<Integer>();

      for(int i = 0; i < 10000; i++){

          intset.add(rand.nextInt(30));

      }

      System.out.println(intset);

  }

}

 

                         本例中,intset中插入了10000次,由於不保留重覆元素最後輸出結果數目<=30。

  • TreeSet

                         TreeSet使用紅黑樹來實現存儲元素, 紅黑樹的好處是可以插入之後維持集合的有序性。                               

 

import java.util.*;

public class SortIntegerSet {

  private static Random rand;

   public static void main(String[] args) {

     rand = new Random(47);

     Set<Integer> sintset = new TreeSet<Integer>();

       for(int i = 0; i < 10000; i++){

          sintset.add(rand.nextInt(20));

       }

       System.out.println(sintset);

  }

}

 

  • LinkedHashSet

                          顧名思義,LinkedHashSet使用了鏈表來保持插入順序,不過為了提高查詢效率,也使用了散列

  • Queue介面
    • LinkedList

                        LinkedList實現了Queue介面,提供了方法支持隊列的行為,在以後的系列我們會深入講解如何用               

                 LinkedList實現隊列。

  • PriorityQueue

                         與普通隊列不同,優先隊列每次彈出的是優先順序最高的元素。可以通過提供自己的Comparator來修改     

                 預設的優先順序順序。       

  • Map介面
    • HashMap

             HashMap通過散列機制,用來快速訪問

  • TreeMap

                TreeMap保持"key"處於排序狀態,訪問速度不如HashMap

  • LinkedHashMap

                LinkedHashMap保持元素插入時順序,同時提供散列實現快速訪問

    關於Map的散列實現是非常重要的,實現Map的原理(關聯數組等),hashCode()方法的理解,本系列後面會一一分析。

 

    5.  總結

通過本文的學習,相信讀者對容器的用途,分類,以及容器的層次結構與一些常用容器的基本功能和用法有了較為清晰地瞭解。然而,想要更好的使用容器類,還必須瞭解每種容器具體的方法,源碼,以及線程安全的實現。在本系列的後續部分,將帶大家繼續深入討論這些內容。

如果覺得本文對您有所幫助的話,就給俺推薦一個吧~

作者:I'm coding
鏈接:http://www.cnblogs.com/ACFLOOD/
著作權歸作者所有。商業轉載請聯繫作者獲得授權,非商業轉載請註明出處。


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

-Advertisement-
Play Games
更多相關文章
  • 1. 引言 一個項目的通常都是從Demo開始,不斷為項目添加新的功能以及重構,也許剛開始的時候代碼顯得非常凌亂,毫無設計可言。但是隨著項目的迭代,往往需要將很多相同功能的代碼抽取出來,這也是設計模式的開始。熟練運用設計模式應該是每一個軟體開發人員的必備技能。今天給大家介紹幾個常用的設計模式。 2. ... ...
  • 作為一個豬拱性能的程式猿,不會使用fiddler來協助自己分析問題是萬萬不能的。還記得剛入職的時候老大提過的幾個必須要熟練使用的工具中第一個就是fiddler。雖然接觸了快一年了,但是還是一知半解的。下午找同事幫忙分析了個記憶體溢出的問題,剛學了一招如何使用fiddler來分析oom類問題。當然以下內 ...
  • 問題背景:在使用普通的SelfHost時,調用其它工程的dll(其實就是把WebApi寫到一個單獨的工程方便管理),通過載入其他工程的dll然後再訪問webapi是沒有問題的。 但是在使用Owin SelfHost時,調用其它工程的dll,訪問WebApi時會拋出No type was found ...
  • 輔助器方法 在開發ASP.NET MVC項目時,經常會用到輔助器方法,它能夠提供很多遍歷的工作,比如可以對代碼塊和標記進行打包等。下麵通過新建一個示例項目來看看其在實際使用中的情況。 示例項目 項目名:HelperMethods 模板:Basic(基本) 項目名:HelperMethods 模板:B ...
  • 前言 最近這段時間除了工作,所有的時間都是在移植我以前實現的一個Owin框架,相當移植到到Core的話肯定會有很多坑,這個大家都懂,以後幾篇文章可能會圍繞這個說下,暫時就叫《Dotnet Core踩坑記》吧,呵呵。 接下來我對我在移植過程中發現的一些問題進行了總結,今天主要說說Owin。說到Owin ...
  • 創建自定義視圖引擎 一般情況下直接使用MVC框架自帶的內建視圖引擎即可,但如果想知道視圖引擎是如何工作的,就需要從建立一個自定義視圖引擎開始了。通過之前的學習我們都知道了內建視圖引擎包括Razor和ASPX兩種,ASPX是針對舊版本MVC程式的,他主要是維護舊版本MVC應用程式,保持系統的相容性而保 ...
  • 我們可以使用jdk內置的 Locale 類來實現java語言的國際化。使用方法很簡單: 命名格式為: xxx_語言代碼_國家代碼 我們這裡 用到了 中英文名稱為: RetrievingRequestXMLError=Error retrieving requestXML from HTTP POST ...
  • #include <iostream>#include <algorithm>#include <map> using namespace std; int main() { int n, i, *arr1, *arr2; map<int, int> match; while(cin>>n) { a ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...