Java集合的有序無序問題和線程安全與否問題


首先,清楚有序和無序是什么意思:

集合的有序、無序是指插入元素時,保持插入的順序性,也就是先插入的元素優先放入集合的前面部分。 
而排序是指插入元素后,集合中的元素是否自動排序。(例如升序排序)

 

1.有序集合:集合里的元素可以根據key或index訪問
.無序集合:集合里的元素只能遍歷。
有序集合在屬性的增加,刪除及修改中擁有較好的性能表現。

 

Set集合一般是無序的。實現hash算法的集合一般是無序的,例如hashMap,hashTable

List集合一般是有序的。

 

底層是Tree的一般是有序的,例如TreeSet,TreeMap

底層有lined的一般是有序的,它會用鏈表維護元素的順序。

 

綜上:

有序的:

List的所有子類

無序的:一般的Set,除了TreeSet,linkedHashSet等底層是樹或者鏈表的。一般的Map,除了底層是樹或者鏈表的。

 

已知的線程安全集合:

vector,hashtable,statck,enumeration


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM