本文目錄一覽:
java容器的組件包括什麼?
JAVA的容器包括如下:
List,Map,Set ,Collection ,List ,LinkedList ,ArrayList ,Vector ,Stack ,Set
Map ,Hashtable ,HashMap ,WeakHashMap
數據容器主要分為了兩類:
Collection: 存放獨立元素的序列。
Map:存放key-value型的元素對。(這對於需要利用key查找value的程序十分的重要!)
從類體系圖中可以看出,Collection定義了Collection類型數據的最基本、最共性的功能接口,而List對該接口進行了拓展。
其中各個類的適用場景有很大的差別,在使用時,應該根據需要靈活的進行選擇。此處介紹最為常用的四個容器:
LinkedList :其數據結構採用的是鏈表,此種結構的優勢是刪除和添加的效率很高,但隨機訪問元素時效率較ArrayList類低。
ArrayList:其數據結構採用的是線性表,此種結構的優勢是訪問和查詢十分方便,但添加和刪除的時候效率很低。
HashSet: Set類不允許其中存在重複的元素(集),無法添加一個重複的元素(Set中已經存在)。HashSet利用Hash函數進行了查詢效率上的優化,其contain()方法經常被使用,以用於判斷相關元素是否已經被添加過。
HashMap: 提供了key-value的鍵值對數據存儲機制,可以十分方便的通過鍵值查找相應的元素,而且通過Hash散列機制,查找十分的方便。
java容器有哪些
容器是一個Java所編寫的程序,原先必須自行編寫程序以管理對象關係,現在容器都會自動幫您做好。下面來和小編一起詳細了解一下吧。
Java容器是一個Java所編寫的程序。
容器可以管理對象的生命周期、對象與對象之間的依賴關係。
您可以使用一個配置文件(通常是XML),在上面定義好對象的名稱、如何產生(Prototype 方式或Singleton 方式)、哪個對象產生之後必須設定成為某個對象的屬性等,在啟動容器之後,所有的對象都可以直接取用,不用編寫任何一行程序代碼來產生對象,或是建立對象與對象之間的依賴關係。
Java容器類包含List、ArrayList、Vector及map、HashTable、HashMap、Hashset。
以上就是java容器是什麼的詳細內容,更多請關注php中文網其它相關文章!
本文原創發佈php中文網,轉載請註明出處,感謝您的尊重!
java 容器的歸納
容器是用來保存多個對象的東西.嚴格來說是保存對象的引用.因為對象實際的數據是放在另外的地方的.放在容器中的只是指向那塊內存區域的一個標識.
JAVA中內置了數組.數組和其它容器的區別主要有三個:效率,類型,和存放基本類型的能力.JAVA中的數組是一種效率最高的存儲和隨機訪問對象引用序列的方式.它就是一個簡單的線性序列,所以訪問是非常快.但它也損失了其他的特性.當創建一個數組時,它的長度就被固定了.通常是創建一個固定大小的數組,在空間不足時,再創建一個大的數組,然後把舊數組中的所有引用移到新數組中.這種機制被JAVA中的另一個容器:ArrayList採用.所以,ArrayList的效率要比數組低.JAVA中還有一些其他的容器:List,Set(每個對象只保存一份),Map(允許將一個對象和另一對象關聯存儲).它們都是針對Object來處理的.而Object是JAVA中所有類的基類,所以說這些容器可以存放所有JAVA類.注意:基本類型如:boolean char byte short long float double void..不繼承Object,所以這些容器不能存放這些.如果要存進去必須用JAVA為這些類提供的 包裝類它們對應的包裝類是: Boolean Character Byte Short Integer Long Float Double Void
因為基本類型是不繼承自Object的,所以強制轉換也是不可能的.必須用包裝類進行強制轉換.比如說將一個String強制轉換成int型,必須:Integer.praseInt("3");必須用包裝類來.
經包裝類包裝後的基本類型就可以隨便往容器里放了.
JAVA容器的缺點:
1)將對象保存到容器的時候它的類型信息就丟失了.因為容器是針對Object的.所以可以將不同類型的對象放入同一個容器中.而數組則不同,一個數組裡只能存同一類型的對象.
2)在從容器中取出對象使用時必須進行類型轉換.
當然,上面的問題可以通過泛型來解決.
容器的選擇:
容器實際上只有三種:Map , List, Set;但每種接口都有不同的實現版本.它們的區別可以歸納為由什麼在背後支持它們.也就是說,你使用的接口是由什麼樣的數據結構實現的.
List的選擇:
比如:ArrayList和LinkedList都實現了List接口.因此無論選擇哪一個,基本操作都一樣.但ArrayList是由數組提供底層支持.而LinkedList是由雙向鏈表實現的.所以,如果要經常向List里插入或刪除數據,LinkedList會比較好.否則應該用速度更快的ArrayList.
Set的選擇
HashSet總是比TreeSet 性能要好.而後者存在的理由就是它可以維持元素的排序狀態.所以,如果需要一個排好序的Set時,才應該用TreeSet
Map選擇:
同上,盡量選擇HashMap,只要需要排好序的確Map時才用Treemap
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/191117.html