溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java中集合關(guān)系圖的示例分析

發(fā)布時(shí)間:2021-08-17 10:40:42 來(lái)源:億速云 閱讀:88 作者:小新 欄目:編程語(yǔ)言

這篇文章主要介紹Java中集合關(guān)系圖的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

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

Java中集合關(guān)系圖的示例分析

Java中集合關(guān)系圖的示例分析  

幾個(gè)面試常見(jiàn)問(wè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是這個(gè)集合體系中最主要的三個(gè)接口。
      其中List和Set繼承自Collection接口。
      Set不允許元素重復(fù)。HashSet和TreeSet是兩個(gè)主要的實(shí)現(xiàn)類。
      List有序且允許元素重復(fù)。ArrayList、LinkedList和Vector是三個(gè)主要的實(shí)現(xiàn)類。
      Map也屬于集合系統(tǒng),但和Collection接口不同。Map是key對(duì)value的映射集合,其中key列就是一個(gè)集合。key不能重復(fù),但是value可以重復(fù)。HashMap、TreeMap和Hashtable是三個(gè)主要的實(shí)現(xiàn)類。
      SortedSet和SortedMap接口對(duì)元素按指定規(guī)則排序,SortedMap是對(duì)key列進(jìn)行排序。

3.Q:Comparable和Comparator區(qū)別

    A:調(diào)用java.util.Collections.sort(List list)方法來(lái)進(jìn)行排序的時(shí)候,List內(nèi)的Object都必須實(shí)現(xiàn)了Comparable接口。
        java.util.Collections.sort(List list,Comparator c),可以臨時(shí)聲明一個(gè)Comparator 來(lái)實(shí)現(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接口對(duì)Collection進(jìn)行了簡(jiǎn)單的擴(kuò)充,它的具體實(shí)現(xiàn)類常用的有ArrayList和LinkedList。你可以將任何東西放到一個(gè)List容器中,并在需要時(shí)從中取出。ArrayList從其命名中可以看出它是一種類似數(shù)組的形式進(jìn)行存儲(chǔ),因此它的隨機(jī)訪問(wèn)速度極快,而LinkedList的內(nèi)部實(shí)現(xiàn)是鏈表,它適合于在鏈表中間需要頻繁進(jìn)行插入和刪除操作。在具體應(yīng)用時(shí)可以根據(jù)需要自由選擇。前面說(shuō)的Iterator只能對(duì)容器進(jìn)行向前遍歷,而ListIterator則繼承了Iterator的思想,并提供了對(duì)List進(jìn)行雙向遍歷的方法。

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

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

遍歷Map的方式:

//最常規(guī)的一種遍歷方法,最常規(guī)就是最常用的,雖然不復(fù)雜,但很重要,這是我們最熟悉的,就不多說(shuō)了!! 
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進(jìn)行遍歷,它的優(yōu)點(diǎn)在于可以根據(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ù)雜的一種遍歷在這里,呵呵~~他很暴力哦,它的靈活性太強(qiáng)了,想得到什么就能得到什么~~ 
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的另外一種簡(jiǎn)練寫法(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()); 
 
  } 
 
 
}

以上是“Java中集合關(guān)系圖的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI