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

專注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ù)文檔推薦 >>
主站蜘蛛池模板: 最近免费字幕中文大全视频 | 97人人艹 | 天天爱天天做天天干 | 国产成人a在一区线观看高清 | 午夜看毛片 | 天堂中文在线网 | 全免费午夜一级毛片真人 | 久久久久夜色精品波多野结衣 | 在线亚洲+欧美+日本专区 | 日韩欧美视频一区二区 | 精品精品精品 | 欧美色综合网站 | 毛片免费在线观看 | 成人福利视频网站 | 亚洲国产精品成人综合久久久 | 免费v片在线观看视频网站 免费不卡中文字幕在线 | 日韩美女一级毛片 | 欧美理论影院在线观看免费 | 欧美成人观看 | 欧美激情在线精品一区二区 | 国产欧美日韩不卡 | 91麻豆精品一二三区在线 | 国内精品福利 | 91精品国产肉丝高跟在线 | 欧美精品一区在线看 | 免费一级夫妻a | 欧美日本韩国国产 | 成人亚洲欧美日韩在线 | 人人干人人艹 | 欧洲男女啪啪免费观看 | 羞羞影院体验区 | 中文字幕精品视频在线观 | 亚洲国产一区二区三区综合片 | 1级黄色录像 | 小明视频免费永久在线网 | 人人人人爽 | 特级淫片波多野结衣 | 日日摸夜夜添夜夜添一区二区 | 国产大臿蕉香蕉大视频女 | 毛片在线高清免费观看 | 国产精品人人爽人人做 |