Set三個接口存取元素時?
List特點:元素有放入順序,元素可重復 Set特點:元素無放入順序,元素不可重復(注意:元素雖然無放入順序,但是元素在set中的位置是有該元素的HashCode決定的,其位置其實是固定的) 。
Map特點:元素按鍵值對存儲,無放入順序 (應該知道什么是鍵值對吧!)List接口有三個實現類:LinkedList,ArrayList,Vector LinkedList:底層基于鏈表實現,鏈表內存是散亂的,每一個元素存儲本身內存地址的同時還存儲下一個元素的地址。
鏈表增刪快,查找慢 ArrayList和Vector的區別:ArrayList是非線程安全的,效率高;Vector是基于線程安全的,效率低 Set接口有兩個實現類:HashSet(底層由HashMap實現),LinkedHashSet SortedSet接口有一個實現類:TreeSet(底層由平衡二叉樹實現) Query接口有一個實現類:LinkList Map接口有三個實現類:HashMap,HashTable,LinkeHashMap HashMap非線程安全,高效,支持null;HashTable線程安全,低效,不支持null SortedMap有一個實現類:TreeMap 其實最主要的是,list是用來處理序列的,而set是用來處理集的。Map是知道的,存儲的是鍵值對 set 一般無序不重復.map kv 結構 list 有序。
3.首先list,set的上層接口是Collection接口。list底層存儲數據是通過數組儲存。 他有實現類ArrayList和LinkedList比較常用。Vector這個類現在基本沒用。Vector和ArrayList是數組,插入數據較慢,查詢較快。區別在Vector是線程安全的,所以處理速度不如ArrayList。linkedList是鏈表結構儲存,插入數據較快,查詢較慢。
4.Set集合最大特點不存重復元素,Set集合有自己的排序方式,所以取出時順序和存儲時不一樣。常用實現類HashSetHashSet儲存會判斷值的Hash值,相同的話則不儲存。Map接口是一個鍵值對集合,鍵不可以重復,值無所謂。Map集合也是有自己的排序方式常用實現類HashMap.實際Map集合存的就是映射。