国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - Java中集合關(guān)系圖及常見操作詳解

Java中集合關(guān)系圖及常見操作詳解

2021-01-29 11:46zztfj Java教程

這篇文章主要為大家詳細介紹了Java中集合關(guān)系圖及常見操作,解析Java中的集合類型的繼承關(guān)系圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下

下面是一張下載的java中的集合類型的繼承關(guān)系圖,便于正確的理解和使用相應(yīng)的集合類型。

Java中集合關(guān)系圖及常見操作詳解

Java中集合關(guān)系圖及常見操作詳解  

幾個面試常見問題:

1.q:arraylist和vector有什么區(qū)別?hashmap和hashtable有什么區(qū)別?

   a:vector和hashtable是線程同步的(synchronized)。性能上,arraylist和hashmap分別比vector和hashtable要好。

2.q:大致講解java集合的體系結(jié)構(gòu)

   a:list、set、map是這個集合體系中最主要的三個接口。
      其中l(wèi)ist和set繼承自collection接口。
      set不允許元素重復(fù)。hashset和treeset是兩個主要的實現(xiàn)類。
      list有序且允許元素重復(fù)。arraylist、linkedlist和vector是三個主要的實現(xiàn)類。
      map也屬于集合系統(tǒng),但和collection接口不同。map是key對value的映射集合,其中key列就是一個集合。key不能重復(fù),但是value可以重復(fù)。hashmap、treemap和hashtable是三個主要的實現(xiàn)類。
      sortedset和sortedmap接口對元素按指定規(guī)則排序,sortedmap是對key列進行排序。

3.q:comparable和comparator區(qū)別

    a:調(diào)用java.util.collections.sort(list list)方法來進行排序的時候,list內(nèi)的object都必須實現(xiàn)了comparable接口。
        java.util.collections.sort(list list,comparator c),可以臨時聲明一個comparator 來實現(xiàn)排序。
        collections.sort(imagelist, new comparator() {
            public int compare(object a, object b) {
                int ordera = integer.parseint( ( (image) a).getsequence());
                int orderb = integer.parseint( ( (image) b).getsequence());
                return ordera - orderb;
           }
        });
        如果需要改變排列順序
        改成return orderb - ordera 即可。 

list接口對collection進行了簡單的擴充,它的具體實現(xiàn)類常用的有arraylist和linkedlist。你可以將任何東西放到一個list容器中,并在需要時從中取出。arraylist從其命名中可以看出它是一種類似數(shù)組的形式進行存儲,因此它的隨機訪問速度極快,而linkedlist的內(nèi)部實現(xiàn)是鏈表,它適合于在鏈表中間需要頻繁進行插入和刪除操作。在具體應(yīng)用時可以根據(jù)需要自由選擇。前面說的iterator只能對容器進行向前遍歷,而listiterator則繼承了iterator的思想,并提供了對list進行雙向遍歷的方法。

set接口也是collection的一種擴展,而與list不同的時,在set中的對象元素不能重復(fù),也就是說你不能把同樣的東西兩次放入同一個set容器中。它的常用具體實現(xiàn)有hashset和treeset類。hashset能快速定位一個元素,但是你放到hashset中的對象需要實現(xiàn)hashcode()方法,它使用了前面說過的哈希碼的算法。而treeset則將放入其中的元素按序存放,這就要求你放入其中的對象是可排序的,這就用到了集合框架提供的另外兩個實用類comparable和comparator。一個類是可排序的,它就應(yīng)該實現(xiàn)comparable接口。有時多個類具有相同的排序算法,那就不需要在每分別重復(fù)定義相同的排序算法,只要實現(xiàn)comparator接口即可。集合框架中還有兩個很實用的公用類:collections和arrays。collections提供了對一個collection容器進行諸如排序、復(fù)制、查找和填充等一些非常有用的方法,arrays則是對一個數(shù)組進行類似的操作。

map是一種把鍵對象和值對象進行關(guān)聯(lián)的容器,而一個值對象又可以是一個map,依次類推,這樣就可形成一個多級映射。對于鍵對象來說,像set一樣,一個map容器中的鍵對象不允許重復(fù),這是為了保持查找結(jié)果的一致性;如果有兩個鍵對象一樣,那你想得到那個鍵對象所對應(yīng)的值對象時就有問題了,可能你得到的并不是你想的那個值對象,結(jié)果會造成混亂,所以鍵的唯一性很重要,也是符合集合的性質(zhì)的。當然在使用過程中,某個鍵所對應(yīng)的值對象可能會發(fā)生變化,這時會按照最后一次修改的值對象與鍵對應(yīng)。對于值對象則沒有唯一性的要求。你可以將任意多個鍵都映射到一個值對象上,這不會發(fā)生任何問題(不過對你的使用卻可能會造成不便,你不知道你得到的到底是那一個鍵所對應(yīng)的值對象)。map有兩種比較常用的實現(xiàn):hashmap和treemap。hashmap也用到了哈希碼的算法,以便快速查找一個鍵,treemap則是對鍵按序存放,因此它便有一些擴展的方法,比如firstkey(),lastkey()等,你還可以從treemap中指定一個范圍以取得其子map。鍵和值的關(guān)聯(lián)很簡單,用pub(object key,object value)方法即可將一個鍵與一個值對象相關(guān)聯(lián)。用get(object key)可得到與此key對象所對應(yīng)的值對象。 

遍歷map的方式:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
//最常規(guī)的一種遍歷方法,最常規(guī)就是最常用的,雖然不復(fù)雜,但很重要,這是我們最熟悉的,就不多說了!!
public static void work(map<string, student> map) {
 
  collection<student> c = map.values();
 
  iterator it = c.iterator();
 
  for (; it.hasnext();) {
 
    system.out.println(it.next());
 
  }
 
}
 
  
 
// 利用keyset進行遍歷,它的優(yōu)點在于可以根據(jù)你所想要的key值得到你想要的 values,更具靈活性!!
public static void workbykeyset(map<string, student> map) {
 
  set<string> key = map.keyset();
 
  for (iterator it = key.iterator(); it.hasnext();) {
 
    string s = (string) it.next();
 
    system.out.println(map.get(s));
 
  }
 
}
 
// 比較復(fù)雜的一種遍歷在這里,呵呵~~他很暴力哦,它的靈活性太強了,想得到什么就能得到什么~~
public static void workbyentry(map<string, student> map) {
 
  set<map.entry<string, student>> set = map.entryset();
 
  for (iterator<map.entry<string, student>> it = set.iterator(); it
      .hasnext();) {
 
    map.entry<string, student> entry = (map.entry<string, student>) it
        .next();
 
    system.out.println(entry.getkey() + "—>" + entry.getvalue());
 
  }
 
}
 
//map.entry的另外一種簡練寫法(foreach遍歷方式)
public static void workbyentry(map<string, student> map) {
 
  set<map.entry<string, student>> set = map.entryset();
 
  for (map.entry<string, student> me : set) {
 
    system.out.println(me.getkey() + "—>" + me.getvalue());
 
  }
 
 
}

 以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。

原文鏈接:http://blog.csdn.net/zztfj/article/details/7563262

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 一区二区免费在线播放 | 国产中文字幕亚洲 | 国变精品美女久久久久av爽 | 五月天婷婷社区 | 亚洲伦理电影 | 久久成人免费视频 | 自拍偷拍精品 | 亚洲精品一区二三区不卡 | 国产精品视频一区二区三区不卡 | 亚洲视频成人 | 国产一区二区三区在线免费看 | 亚洲h视频 | 电影91久久久 | 亚洲国产欧美日韩 | 日韩欧美一区二区三区免费观看 | 国产色综合视频 | 成人刺激视频在线 | 国产a区| av电影免费在线看 | 国产精品美女久久久久久久久久久 | 日韩在线成人av | 免费观看在线午夜影视 | 亚洲狠狠爱 | 日韩一区二区电影 | 青青久视频| 羞羞动漫在线观看 | 亚洲精品一 | 日韩精品一区二区三区在线 | 久久国产一区二区 | 亚洲精品第一页 | 羞羞动漫网 | 欧美亚洲综合久久 | 色五月激情综合网 | 久久综合九九 | 91香蕉| 一级毛片免费视频 | 欧美高清成人 | 亚洲网在线| 久久久久久亚洲 | 亚洲国产精品一区二区第一页 | 欧美亚洲天堂 |