Java工具包提供了強大的數據結構。在Java中的數據結構主要包括如下幾種接口和類:html
枚舉(Enumeration)接口雖然它自己不屬於數據結構,但它在其餘數據結構的範疇裏應用很廣。 枚舉(The Enumeration)接口定義了一種從數據結構中取回連續元素的方式。java
例如,枚舉定義了一個叫nextElement 的方法,該方法用來獲得一個包含多元素的數據結構的下一個元素。數組
關於枚舉接口的更多信息,請參見枚舉(Enumeration)。數據結構
位集合類實現了一組能夠單獨設置和清除的位或標誌。工具
該類在處理一組布爾值的時候很是有用,你只須要給每一個值賦值一"位",而後對位進行適當的設置或清除,就能夠對布爾值進行操做了。編碼
關於該類的更多信息,請參見位集合(BitSet)。htm
向量(Vector)類和傳統數組很是類似,可是Vector的大小能根據須要動態的變化。對象
和數組同樣,Vector對象的元素也能經過索引訪問。排序
使用Vector類最主要的好處就是在建立對象的時候沒必要給對象指定大小,它的大小會根據須要動態的變化。繼承
關於該類的更多信息,請參見向量(Vector)
棧(Stack)實現了一個後進先出(LIFO)的數據結構。
你能夠把棧理解爲對象的垂直分佈的棧,當你添加一個新元素時,就將新元素放在其餘元素的頂部。
當你從棧中取元素的時候,就從棧頂取一個元素。換句話說,最後進棧的元素最早被取出。
關於該類的更多信息,請參見棧(Stack)。
字典(Dictionary) 類是一個抽象類,它定義了鍵映射到值的數據結構。
當你想要經過特定的鍵而不是整數索引來訪問數據的時候,這時候應該使用Dictionary。
因爲Dictionary類是抽象類,因此它只提供了鍵映射到值的數據結構,而沒有提供特定的實現。
關於該類的更多信息,請參見字典( Dictionary)。
Hashtable類提供了一種在用戶定義鍵結構的基礎上來組織數據的手段。
例如,在地址列表的哈希表中,你能夠根據郵政編碼做爲鍵來存儲和排序數據,而不是經過人名。
哈希表鍵的具體含義徹底取決於哈希表的使用情景和它包含的數據。
關於該類的更多信息,請參見哈希表(HashTable)。
Properties 繼承於 Hashtable.Properties 類表示了一個持久的屬性集.屬性列表中每一個鍵及其對應值都是一個字符串。
Properties 類被許多Java類使用。例如,在獲取環境變量時它就做爲System.getProperties()方法的返回值。
關於該類的更多信息,請參見屬性(Properties)。