大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 最常用的java數據結構類型哪些

最常用的java數據結構類型哪些

更新時間:2019-10-29 17:05:02 來源:動力節點 瀏覽2486次

 

Java數據結構是一門研究非數值計算的程序設計問題中計算機的操作對象以及它們之間的關系和操作等等的學科。那么最常用的java數據結構類型哪些?下面隨動力節點java學院小編一起來看看。


最常用的java數據結構類型哪些


  Map接口


  請注意,Map沒有繼承Collection接口,Map提供key到value的映射。一個Map中不能包含相同的key,每個key只能映射一個value。


  Map接口提供3種集合的視圖,Map的內容可以被當作一組key集合,一組value集合,或者一組key-value映射。


  List接口


  List是有序的Collection,用戶能夠使用索引(元素在List中的位置,類似于數組下標)來訪問List中的元素,這類似于Java的數組。


  和下面要提到的Set不同,List允許有相同的元素。


  Collection接口


  兩個標準的構造函數:無參數的構造函數用于創建一個空的Collection;有一個Collection參數的構造函數用于創建一個新的Collection


  如何遍歷:


Iteratorit=collection.iterator;//獲得一個迭代子


  while(it.hasNext){


  Objectobj=it.next;//得到下一個元素


  }


  由Collection接口派生的兩個接口是List和Set。


  ArrayList類


  ArrayList實現了可變大小的數組。


  它允許所有元素,包括null。


  ArrayList沒有同步。


  Hashtable類


  Hashtable繼承Map接口,實現一個key-value映射的哈希表。任何非空(non-null)的對象都可作為key或者value。


  添加數據使用put(key,value),取出數據使用get(key),這兩個基本操作的時間開銷為常數。Hashtable通過initialcapacity和loadfactor兩個參數調整性能。通常缺省的loadfactor0.75較好地實現了時間和空間的均衡。增大loadfactor可以節省空間但相應的查找時間將增大,這會影響像get和put這樣的操作。


  使用Hashtable的簡單示例如下,將1,2,3放到Hashtable中,他們的key分別是“one”,“two”,“three”:


  Hashtablenumbers=newHashtable;


  numbers.put(“one”,newInteger(1));


  numbers.put(“two”,newInteger(2));


  numbers.put(“three”,newInteger(3));


  要取出一個數,比如2,用相應的key:


  Integern=(Integer)numbers.get(“two”);


  System.out.println(“two=”+n);


  由于作為key的對象將通過計算其散列函數來確定與之對應的value的位置,因此任何作為key的對象都必須實現hashCode和equals方法。hashCode和equals方法繼承自根類Object,如果你用自定義的類當作key的話,要相當小心,按照散列函數的定義,如果兩個對象相同,即obj1.equals(obj2)==true,則它們的hashCode必須相同,但如果兩個對象不同,則它們的hashCode不一定不同,如果兩個不同對象的hashCode相同,這種現象稱為沖突,沖突會導致操作哈希表的時間開銷增大,所以盡量定義好的hashCode方法,能加快哈希表的操作。


  如果相同的對象有不同的hashCode,對哈希表的操作會出現意想不到的結果(期待的get方法返回null),要避免這種問題,只需要牢記一條:要同時復寫equals方法和hashCode方法,而不要只寫其中一個。


  Hashtable是同步的。


  Stack類


  Stack繼承自Vector,實現一個后進先出的堆棧。Stack提供5個額外的方法使得Vector得以被當作堆棧使用。基本的push和pop方法,還有peek方法得到棧頂的元素,empty方法測試堆棧是否為空,search方法檢測一個元素在堆棧中的位置。Stack剛創建后是空棧。


  Set接口


  Set是一種不包含重復的元素的Collection,即任意的兩個元素e1和e2都有e1.equals(e2)==false,Set最多有一個null元素。


  很明顯,Set的構造函數有一個約束條件,傳入的Collection參數不能包含重復的元素。


  請注意:必須小心操作可變對象(MutableObject)。如果一個Set中的可變元素改變了自身狀態導致Object.equals(Object)==true將導致一些問題。


  WeakHashMap類


  WeakHashMap是一種改進的HashMap,它對key實行“弱引用”,如果一個key不再被外部所引用,那么該key可以被GC回收。


  Vector類


  Vector非常類似ArrayList,但是Vector是同步的。


  HashMap類


  HashMap和Hashtable類似,不同之處在于HashMap是非同步的,并且允許null,即nullvalue和nullkey。但是將HashMap視為Collection時(values方法可返回Collection),其迭代子操作時間開銷和HashMap的容量成比例。因此,如果迭代操作的性能相當重要的話,不要將HashMap的初始化容量設得過高,或者loadfactor過低。


  LinkedList類


  允許null元素


  此外LinkedList提供額外的get,remove,insert方法在LinkedList的首部或尾部。這些操作使LinkedList可被用作堆棧(stack),隊列(queue)或雙向隊列(deque)。


  注意LinkedList沒有同步方法。如果多個線程同時訪問一個List,則必須自己實現訪問同步。一種解決方法是在創建List時構造一個同步的List:


  Listlist=Collections.synchronizedList(newLinkedList(...));


最常用的java數據結構類型哪些


以上就是動力節點java學院小編介紹的“最常用的java數據結構類型哪些”的內容,希望對大家有幫助,如有疑問,請在線咨詢,有專業老師隨時為你服務。


相關推薦


誰有好的java數據結構學習方法


提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 久久精品综合 | 一区二区三区欧美日韩 | 香蕉97超级碰碰碰碰碰久 | 欧美专区一区二区三区 | 欧美乱妇高清视频免欢看关 | 久久久国产99久久国产久 | 国产成人亚洲精品77 | 久久综合九色综合97_ 久久久 | 日本不卡免免费观看 | 国产精品国产自线在线观看 | 欧美亚洲国产视频 | 午夜国产精品久久影院 | 青青热久免费精品视频精品 | 成人精品一区二区三区中文字幕 | 免费一级毛片在级播放 | 亚洲精品乱码久久久久蜜桃 | 久久综合偷偷噜噜噜色 | 国产精品久久久久久久久久日本 | aaaa级日本片免费视频 | 亚洲国产综合精品 | 亚洲999| 99久久999久久久综合精品涩 | 久一视频在线观看 | 久久亚洲国产精品一区二区 | 福利视频不卡 | 亚洲国产精品不卡毛片a在线 | a大片久久爱一级 | 成 人 黄 色 视频 免费观看 | 狠狠影视 | 亚洲第一在线 | 国产做受视频激情播放 | 尹人综合网 | 青青青青啪视频在线观看 | 国产美女久久精品香蕉69 | 一级毛片免费不卡在线 | 国产成人久久综合热 | 国产精品视频一区二区三区不卡 | 亚洲精品美女久久久久99 | 国产成人精品男人的天堂网站 | 国产麻豆va精品视频 | 99视频观看|