获取后台集合并遍历_java集合类汇总,终于出总结了,再也不用担心混淆了
一:集合與數組
數組(可以存儲基本數據類型)是用來存現對象的一種容器,但是數組的長度固定,不適合在對象數量未知的情況下使用。
集合(只能存儲對象,對象類型可以不一樣)的長度可變,可在多數情況下使用。
二、層次關系
如圖所示:圖中,實線邊框的是實現類,折線邊框的是抽象類,而點線邊框的是接口
Collection接口是集合類的根接口,java中沒有提供這個接口的直接的實現類。但是卻讓其被繼承產生了兩個接口就是Set和List。Set中不能包含重復的元素。List是一個有序的集合,提供了按索引訪問的方式。
Map是Java.util包中的另一個接口,它和Collection接口沒有關系,是互相獨立的,但是都屬于集合類的一部分。Map包含了Key-value對。Map不能包含重復的Key,但是可以包含相同的value。
Iterator,所有的集合類,都實現了Iterator接口,這是一個用于遍歷集合中元素的接口,主要包含以下三種方式:
- hasNext()是否還有下一個元素。
- next()放回下一個元素。
- remove()刪除當前元素。
三、幾種重要的接口和類簡介
1,List(有序,可重復)
List里存放的對象是有序的,同時也是可以重復的,List關注的是索引,擁有一系列和索引相關的方法,查詢速度快。因為往list集合里插入或刪除數據時,會伴隨著后面數據的移動,所有插入刪除數據速度慢。
2,Set(無序,不能重復)
Set里存放的對象是無序,不能重復的,集合中的對象不按特定的方式排序,只是簡單地把對象加入集合中。
3,Map(鍵值對,建唯一,值不唯一)
Map集合中存儲的是鍵值對,鍵不能重復,值可以重復。根據鍵得到值,對map集合遍歷時先得到鍵的set集合,對set集合進行遍歷,得到相應的值。
四、遍歷
在類集中提供了以下四種的常見輸出方式:
1)Iterator:迭代輸出,是使用最多的輸出方式。
2)ListIterator:是Iterator的子接口,專門用于輸出List中的內容。
3)foreach輸出:JDK1.5之后提供的新功能,可以輸出數組或集合。
4)for循環
代碼示例如下:
for的形式:for(int i=0;i
foreach的形式: for(int i:arr){...}
iterator的形式:
Iterator it = arr.iterator();
while(it.hasNext()){ object o =it.next(); ...}
五、ArrayList和LinkedList
ArrayList和LinkedList在用法上沒有區別,但是在功能上還是有區別的。LinkedList經常用在增刪操作較多而查詢操作很少的情況下,ArrayList則相反。
六、Map集合
實現類:HashMap、Hashtable、LinkedHashMap和TreeMap
HashMap
HashMap是最常用的Map,它根據鍵的HashCode值存儲數據,根據鍵可以直接獲取它的值,具有很快的訪問速度,遍歷時,取得數據的順序是完全隨機的。因為鍵對象不可以重復,所以HashMap最多只允許一條記錄的鍵為Null,允許多條記錄的值為Null,是非同步的
Hashtable
Hashtable與HashMap類似,是HashMap的線程安全版,它支持線程的同步,即任一時刻只有一個線程能寫Hashtable,因此也導致了Hashtale在寫入時會比較慢,它繼承自Dictionary類,不同的是它不允許記錄的鍵或者值為null,同時效率較低。
ConcurrentHashMap
線程安全,并且鎖分離。ConcurrentHashMap內部使用段(Segment)來表示這些不同的部分,每個段其實就是一個小的hash table,它們有自己的鎖。只要多個修改操作發生在不同的段上,它們就可以并發進行。
LinkedHashMap
LinkedHashMap保存了記錄的插入順序,在用Iteraor遍歷LinkedHashMap時,先得到的記錄肯定是先插入的,在遍歷的時候會比HashMap慢,有HashMap的全部特性。
TreeMap
TreeMap實現SortMap接口,能夠把它保存的記錄根據鍵排序,默認是按鍵值的升序排序(自然順序),也可以指定排序的比較器,當用Iterator遍歷TreeMap時,得到的記錄是排過序的。不允許key值為空,非同步的;
map的遍歷
第一種:KeySet()
將Map中所有的鍵存入到set集合中。因為set具備迭代器。所有可以迭代方式取出所有的鍵,再根據get方法。獲取每一個鍵對應的值。 keySet():迭代后只能通過get()取key 。
取到的結果會亂序,是因為取得數據行主鍵的時候,使用了HashMap.keySet()方法,而這個方法返回的Set結果,里面的數據是亂序排放的。
典型用法如下:
Map map = new HashMap();
map.put("key1
總結
以上是生活随笔為你收集整理的获取后台集合并遍历_java集合类汇总,终于出总结了,再也不用担心混淆了的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysqlorderby数字字符串排序_
- 下一篇: 三年级优秀书籍推荐_西关小学书画比赛优秀