亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java集合繼承關系圖分享

 更新時間:2017年11月02日 09:30:34   作者:kosamino  
這篇文章主要為大家詳細介紹了java集合繼承關系圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下

  面向對象語言對事物的體現(xiàn)都是以對象的形式,所以為了方便對多個對象的操作,就對對象進行存儲,集合就是存儲對象最常用的一種方式。

  數(shù)組雖然也可以存儲對象,但長度是固定的;集合長度是可變的,數(shù)組中可以存儲基本數(shù)據(jù)類型,集合只能存儲對象。

  集合類的特點:集合只用于存儲對象,集合長度是可變的,集合可以存儲不同類型的對象。

 

  

  上述類圖中,實線邊框的是實現(xiàn)類,比如ArrayList,LinkedList,HashMap等,折線邊框的是抽象類,比如AbstractCollection,AbstractList,AbstractMap等,而點線邊框的是接口,比如Collection,Iterator,List等。

1、Iterator接口

  Iterator接口,這是一個用于遍歷集合中元素的接口,主要包含hashNext(),next(),remove()三種方法。它的一個子接口LinkedIterator在它的基礎上又添加了三種方法,分別是add(),previous(),hasPrevious()。也就是說如果是先Iterator接口,那么在遍歷集合中元素的時候,只能往后遍歷,被遍歷后的元素不會在遍歷到,通常無序集合實現(xiàn)的都是這個接口,比如HashSet,HashMap;而那些元素有序的集合,實現(xiàn)的一般都是LinkedIterator接口,實現(xiàn)這個接口的集合可以雙向遍歷,既可以通過next()訪問下一個元素,又可以通過previous()訪問前一個元素,比如ArrayList。

  抽象類的使用。如果要自己實現(xiàn)一個集合類,去實現(xiàn)那些抽象的接口會非常麻煩,工作量很大。這個時候就可以使用抽象類,這些抽象類中給我們提供了許多現(xiàn)成的實現(xiàn),我們只需要根據(jù)自己的需求重寫一些方法或者添加一些方法就可以實現(xiàn)自己需要的集合類,工作流昂大大降低。

2、Collection (集合的最大接口)繼承關系

  ——List 可以存放重復的內容

  ——Set  不能存放重復的內容,所以的重復內容靠hashCode()和equals()兩個方法區(qū)分

  ——Queue  隊列接口

  ——SortedSet  可以對集合中的數(shù)據(jù)進行排序

  Collection定義了集合框架的共性功能。

  add方法的參數(shù)類型是Object。以便于接收任意類型對象。

  集合中存儲的都是對象的引用(地址)。

3、List的常用子類

  特有方法。凡是可以操作角標的方法都是該體系特有的方法。

  ——ArrayList   線程不安全,查詢速度快

  ——Vector  線程安全,但速度慢,已被ArrayList替代

  ——LinkedList  鏈表結果,增刪速度快

4、Set接口

  Set:元素是無序(存入和取出的順序不一定一致),元素不可以重復。
  ——HashSet:底層數(shù)據(jù)結構是哈希表。是線程不安全的。不同步。
    HashSet是如何保證元素唯一性的呢?
    是通過元素的兩個方法,hashCode和equals來完成。
    如果元素的HashCode值相同,才會判斷equals是否為true。
    如果元素的hashcode值不同,不會調用equals。

    注意,對于判斷元素是否存在,以及刪除等操作,依賴的方法是元素的hashcode和equals方法。

  ——TreeSet:

    有序的存放:TreeSet  線程不安全,可以對Set集合中的元素進行排序

    通過compareTo或者compare方法來保證元素的唯一性,元素以二叉樹的形式存放。

5、Object類

  在實際開發(fā)中經常會碰到區(qū)分同一對象的問題,一個完整的類最好覆寫Object類的hashCode()、equals()、toString()三個方法。

6、集合的輸出

  ——4種常見的輸出方式

  ——Iterator: 迭代輸出,使用最多的輸出方式

  ——ListIterator: Iterator的子接口,專門用于輸出List中的內容

  ——Enumeration

  ——foreach

  在迭代時,不可以通過集合對象的方法操作集合中的元素,因為會發(fā)生ConcurrentModificationException異常。所以,在迭代器時,只能用迭代器的放過操作元素,可是Iterator方法是有限的,只能對元素進行判斷,取出,刪除的操作,如果想要其他的操作如添加,修改等,就需要使用其子接口,ListIterator。該接口只能通過List集合的listIterator方法獲取。

7、Map接口

  Correction、Set、List接口都屬于單值的操作,而Map中的每個元素都使用key——>value的形式存儲在集合中。

  Map集合:該集合存儲鍵值對。一對一對往里存。而且要保證鍵的唯一性。

8、Map接口的常用子類

  Map
  ——HashMap:底層是哈希表數(shù)據(jù)結構,允許使用 null 值和 null 鍵,該集合是不同步的。將hashtable替代,jdk1.2.效率高。
  ——TreeMap:底層是二叉樹數(shù)據(jù)結構。線程不同步??梢杂糜诮omap集合中的鍵進行排序。

9、集合工具類

  Collections:集合框架的工具類。里面定義的都是靜態(tài)方法。

  Collections和Collection有什么區(qū)別?
    Collection是集合框架中的一個頂層接口,它里面定義了單列集合的共性方法。
      它有兩個常用的子接口,
      ——List:對元素都有定義索引。有序的??梢灾貜驮?。
      ——Set:不可以重復元素。無序。

    Collections是集合框架中的一個工具類。該類中的方法都是靜態(tài)的。
      提供的方法中有可以對list集合進行排序,二分查找等方法。
      通常常用的集合都是線程不安全的。因為要提高效率。
      如果多線程操作這些集合時,可以通過該工具類中的同步方法,將線程不安全的集合,轉換成安全的。

10.比較  

  

11.總結:

  List:add/remove/get/set。

    1、ArrayList:其實就是數(shù)組,容量一大,頻繁增刪就是噩夢,適合隨機查找;

    2、LinkedList:增加了push/[pop|remove|pull],其實都是removeFirst;

    3、Vector:歷史遺留產物,同步版的ArrayList,代碼和ArrayList太像;

    4、Stack:繼承自Vector。Java里其實沒有純粹的Stack,可以自己實現(xiàn),用組合的方式,封裝一下LinkedList即可;

    5、Queue:本來是單獨的一類,不過在SUN的JDK里就是用LinkedList來提供這個功能的,主要方法是offer/pull/peek,因此歸到這里呢。

  Set:add/remove??梢杂玫骰蛘咿D換成list。

    1、HashSet:內部采用HashMap實現(xiàn)的;

    2、LinkedHashSet:采用LinkedHashMap實現(xiàn);

    3、TreeSet:TreeMap。

  Map:put/get/remove。

    1、HashMap/HashTable:散列表,和ArrayList一樣采用數(shù)組實現(xiàn),超過初始容量會對性能有損耗;

    2、LinkedHashMap:繼承自HashMap,但通過重寫嵌套類HashMap.Entry實現(xiàn)了鏈表結構,同樣有容量的問題;

    3、Properties:是繼承的HashTable。

    順便說一下Arrays.asList,這個方法的實現(xiàn)依賴一個嵌套類,這個嵌套類也叫ArrayList!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • java實現(xiàn)猜字母游戲

    java實現(xiàn)猜字母游戲

    這篇文章主要為大家詳細介紹了java實現(xiàn)猜字母小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • java實現(xiàn)Object和Map之間的轉換3種方式

    java實現(xiàn)Object和Map之間的轉換3種方式

    本篇文章主要介紹了java實現(xiàn)Object和Map之間的轉換3種方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • java加載屬性配置properties文件的方法

    java加載屬性配置properties文件的方法

    這篇文章主要介紹了java加載屬性配置properties文件的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • Java?SSM框架講解

    Java?SSM框架講解

    這篇文章主要介紹了什么是SSM框架,SSM框架是spring、spring?MVC?、和mybatis框架的整合,是標準的MVC模式。想進一步了解的同學可以詳細參考本文
    2023-03-03
  • java GUI實現(xiàn)加法計算器

    java GUI實現(xiàn)加法計算器

    這篇文章主要為大家詳細介紹了java GUI實現(xiàn)加法計算器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • java 中file.encoding的設置詳解

    java 中file.encoding的設置詳解

    這篇文章主要介紹了java 中file.encoding的設置詳解的相關資料,需要的朋友可以參考下
    2017-04-04
  • SpringBoot項目實現(xiàn)分布式日志鏈路追蹤

    SpringBoot項目實現(xiàn)分布式日志鏈路追蹤

    這篇文章主要給大家介紹了Spring Boot項目如何實現(xiàn)分布式日志鏈路追蹤,文中通過代碼示例給大家介紹的非常詳細,需要的朋友可以參考下
    2023-07-07
  • SpringBoot實現(xiàn)elasticsearch 查詢操作(RestHighLevelClient 的案例實戰(zhàn))

    SpringBoot實現(xiàn)elasticsearch 查詢操作(RestHighLevelClient 

    這篇文章主要給大家介紹了SpringBoot如何實現(xiàn)elasticsearch 查詢操作,文中有詳細的代碼示例和操作流程,具有一定的參考價值,需要的朋友可以參考下
    2023-07-07
  • java基于C/S結構實現(xiàn)多線程聊天室

    java基于C/S結構實現(xiàn)多線程聊天室

    這篇文章主要為大家詳細介紹了java基于C/S結構實現(xiàn)多線程聊天室,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • java爬蟲jsoup解析HTML的工具學習

    java爬蟲jsoup解析HTML的工具學習

    jsoup是一個解析HTML的第三方java庫,它提供了一套非常方便的API,可使用DOM,CSS以及類jQuery的操作方法來取出和操作數(shù)據(jù),本文就來開始jsoup的使用學習
    2022-07-07

最新評論