黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點(diǎn)LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學(xué)習(xí)攻略 最常用的java數(shù)據(jù)結(jié)構(gòu)類型哪些

最常用的java數(shù)據(jù)結(jié)構(gòu)類型哪些

更新時(shí)間:2019-10-29 17:05:02 來源:動力節(jié)點(diǎn) 瀏覽2542次

 

Java數(shù)據(jù)結(jié)構(gòu)是一門研究非數(shù)值計(jì)算的程序設(shè)計(jì)問題中計(jì)算機(jī)的操作對象以及它們之間的關(guān)系和操作等等的學(xué)科。那么最常用的java數(shù)據(jù)結(jié)構(gòu)類型哪些?下面隨動力節(jié)點(diǎn)java學(xué)院小編一起來看看。


最常用的java數(shù)據(jù)結(jié)構(gòu)類型哪些


  Map接口


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


  Map接口提供3種集合的視圖,Map的內(nèi)容可以被當(dāng)作一組key集合,一組value集合,或者一組key-value映射。


  List接口


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


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


  Collection接口


  兩個標(biāo)準(zhǔn)的構(gòu)造函數(shù):無參數(shù)的構(gòu)造函數(shù)用于創(chuàng)建一個空的Collection;有一個Collection參數(shù)的構(gòu)造函數(shù)用于創(chuàng)建一個新的Collection


  如何遍歷:


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


  while(it.hasNext){


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


  }


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


  ArrayList類


  ArrayList實(shí)現(xiàn)了可變大小的數(shù)組。


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


  ArrayList沒有同步。


  Hashtable類


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


  添加數(shù)據(jù)使用put(key,value),取出數(shù)據(jù)使用get(key),這兩個基本操作的時(shí)間開銷為常數(shù)。Hashtable通過initialcapacity和loadfactor兩個參數(shù)調(diào)整性能。通常缺省的loadfactor0.75較好地實(shí)現(xiàn)了時(shí)間和空間的均衡。增大loadfactor可以節(jié)省空間但相應(yīng)的查找時(shí)間將增大,這會影響像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));


  要取出一個數(shù),比如2,用相應(yīng)的key:


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


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


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


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


  Hashtable是同步的。


  Stack類


  Stack繼承自Vector,實(shí)現(xiàn)一個后進(jìn)先出的堆棧。Stack提供5個額外的方法使得Vector得以被當(dāng)作堆棧使用。基本的push和pop方法,還有peek方法得到棧頂?shù)脑?,empty方法測試堆棧是否為空,search方法檢測一個元素在堆棧中的位置。Stack剛創(chuàng)建后是空棧。


  Set接口


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


  很明顯,Set的構(gòu)造函數(shù)有一個約束條件,傳入的Collection參數(shù)不能包含重復(fù)的元素。


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


  WeakHashMap類


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


  Vector類


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


  HashMap類


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


  LinkedList類


  允許null元素


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


  注意LinkedList沒有同步方法。如果多個線程同時(shí)訪問一個List,則必須自己實(shí)現(xiàn)訪問同步。一種解決方法是在創(chuàng)建List時(shí)構(gòu)造一個同步的List:


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


最常用的java數(shù)據(jù)結(jié)構(gòu)類型哪些


以上就是動力節(jié)點(diǎn)java學(xué)院小編介紹的“最常用的java數(shù)據(jù)結(jié)構(gòu)類型哪些”的內(nèi)容,希望對大家有幫助,如有疑問,請?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。


相關(guān)推薦


誰有好的java數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí)方法


提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費(fèi)課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 看片免费黄 | 日韩一区在线播放 | 日韩精品免费观看 | 超人碰碰碰人人成碰人 | 国产精品激情丝袜美女 | 日韩视频免费看 | 真人一级一级特黄高清毛片 | 伊人网综合网 | 亚洲第一福利网站 | 99精彩视频 | 国内精品久久久久久影院老狼 | 色秀视频免费高清网站 | 中文字幕在线免费观看 | 最近2019免费中文字幕6 | 最近免费中文字幕mv | 久久久久国产一级毛片高清片 | 99在线观看视频免费精品9 | 天天夜夜狠狠一区二区三区 | 外国成人xxx在线视频 | 精品国产v无码大片在线观看 | 久久精品国产2020 | 国产精品二区高清在线 | 久久久久夜色精品波多野结衣 | 国产午夜精品久久理论片小说 | 成人精品一区二区www | 日韩精品手机在线 | 天啪天干在线视频 | 天天拍天天操 | 亚洲小视频在线 | 一级女性全黄生活片免费看 | 国产97免费视频 | 亚洲欧洲日产国码 最新 | 我想看黄色毛片 | 国产精品手机视频 | 97国产伦子在线观看 | 亚洲色图国产 | 一级片一级毛片 | 免费色网站 | 亚洲伊人久久大香线蕉苏妲己 | 国产精品大片天天看片 | 午夜做性视频 |