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

面向?qū)ο缶幊?Java中的抽象數(shù)據(jù)類型

 更新時間:2006年12月23日 00:00:00   作者:  
文章來源:互聯(lián)網(wǎng) 作者:PaleSting/CSDN

 在本文中,我們將考察Java中的數(shù)據(jù)類型,但是我們將介紹抽象數(shù)據(jù)類型(ADT)的概念。我們還將通過介紹Java Collections Framework(Java 集合架構)來學習Java定義的一些ADT。

   ADT

   一個ADT是一個僅由保存的數(shù)據(jù)類型和可能在這個數(shù)據(jù)類型上進行的操作定義的。開發(fā)者們只能通過ADT的操作方法來訪問ADT的屬性,而且他們不會知道這個數(shù)據(jù)類型內(nèi)部各種操作是如何實現(xiàn)的。
  
   在Java中,我們常常使用一個接口來給出一個操作集合而不需要透露這些操作實現(xiàn)的細節(jié)。記住一個接口定義了一個方法集而Java類必須實現(xiàn)這個集合以便滿足它的強制性條件或者實現(xiàn)這個接口的一個實例。
  
   線性表,堆棧和隊列

  當我們談論ADT的時候,經(jīng)常會說到線性表,堆棧和隊列。我們不會討論這些數(shù)據(jù)結構的細節(jié),但我們會討論為什么它們被稱為ADT。
  
   一個線性表是有限個元素的集合,其元素以線性的方式進行排列并提供對它的元素的直接訪問。一個堆棧是一個后進先出(LIFO)的有序線性表,元素從堆棧頭加入,并從堆棧頭取出。一個隊列是一個先進先出的有序線性表,元素從隊列尾加入,并從隊列頭取出。
  
   線性表,堆棧和隊列的內(nèi)部結構可以用許多方式實現(xiàn)。例如,我們可以使用一個有序數(shù)組或者一個鏈表來實現(xiàn)每個結構。關鍵的一點是不論你如何實現(xiàn)其內(nèi)部結構,它對外的接口總是不變的。這使得你能夠修改或者升級底層的實現(xiàn)過程而不需要改變公共接口部分。

  Java 集合架構

  Java 2軟件開發(fā)包(SDK)提供了一些新類來支持大多數(shù)常用的ADT。這些類被稱為Java集合類(類似于MFC中的集合類),它們協(xié)同工作從而形成Java 集合架構。這個集合架構提供了一套將數(shù)據(jù)表示成所謂的集合抽象數(shù)據(jù)的接口和類。
  
   java.util.Collection接口被用來表示任意的成組的對象,也就是元素。這個接口提供基本的諸如添加,刪除,和查詢這樣的操作。Collection接口還提供了一個iterator方法。iterator方法返回java.util.Iterator接口的一個實例。而Iterator接口又提供了hasNext, next, 和 remove方法。使用Iterator接口提供的方法,你可以從頭到尾循環(huán)遍歷一個Collection對象中的實例并能夠安全的刪除iterator(游標)所表示的元素。
  
   java.util.AbstractCollection 是所有集合架構類的基礎。AbstractCollection 類提供了對  java.util.Collection 接口中除iterator和size方法以外的所有方法的實現(xiàn)。這兩個例外的方法由所有繼承java.util.AbstractCollection的子類實現(xiàn)。
  
   實現(xiàn)一個接口的類必須提供對所有接口方法的實現(xiàn)。因為集合架構中的一些接口方法是可選的,所以必須有一種方法來通知調(diào)用者某種方法沒有實現(xiàn)。當一個可選的方法被實現(xiàn)而這個方法又并沒有被實現(xiàn)的時候,就會拋出一個UnsupportedOperationException 異常。UnsupportedOperationException 類繼承了RuntimeException 類。這使得調(diào)用者能夠調(diào)用所有的集合操作而不需要把每次調(diào)用都放在一個try-catch對里。
  
   List線性表

   List接口繼承了Collection接口并定義了一個允許相同元素存在的有序集合。List接口還附加了一些使用一個數(shù)值型索引值并基于元素在線性表中的位置來操作Collection中元素的方法。這些操作包括add,get,set和remove。

   List接口還提供了listIterator方法。這個方法返回java.util.ListIterator 接口的一個實例,這個實例能夠讓你從頭至尾或者從尾至頭的遍歷一個線性表。java.util.ListIterator 繼承了java.util.Iterator 接口。因此,它支持對它代表的Collection中的元素的添加和修改。

  下面的例子演示了如何從后向前遍歷一個列表的元素。要完成這個工作,必須在遍歷開始之前把ListIterator定位于列表最后一個元素之后。
  
   ListIterator iter = aList.listIterator(aList.size());
   while (iter.hasPrevious())
   System.out.println(iter.previous().toString());
   }
   集合架構提供了對List接口的兩個實現(xiàn):LinkedList(鏈表)和ArrayList(數(shù)組列表,即靜態(tài)列表)。這兩個實現(xiàn)都支持對其元素的隨機訪問。一個ArrayList實例支持數(shù)組風格的操作并支持數(shù)組大小的改變操作。一個LinkedList的實例則提供了在列表開始和結尾添加,刪除和提供元素的顯式的支持。使用這些新方法,一個程序員可以簡單的把一個LinedList當做堆?;蛘哧犃惺褂?,如下:
  
   LinkedList aQueue = new LinkedList(aCollection);
   aQueue.addFirst(newElement);
   Object   anElement = aQueue.removeLast();
   LinkedList  aStack = new LinkedList(aCollection);
   aStack.addFirst(newElement);
   Object   anElement= aStack.removeFirst();
   表A中的代碼片段使用java.util.ArrayList 和 java.util.LinkedList演示了對java.util.List接口的實現(xiàn)實例的一些常用的操作。這些操作包括添加元素,隨機訪問元素和顯式的在列表尾刪除元素。
  
   知其然不知其所以然是大有好處的

   ADT提供了一個將對象公共接口中的操作和其具體的實現(xiàn)分開的強有力的工具。這使得一個ADT的實現(xiàn)可以不斷變化和演化同時保持其公共接口不變。Java集合架構提供了大量的接口和其實現(xiàn)用來代表基本元素的集合并可以用來創(chuàng)建有用的ADT。

相關文章

  • JDK1.8中的ConcurrentHashMap使用及場景分析

    JDK1.8中的ConcurrentHashMap使用及場景分析

    這篇文章主要介紹了JDK1.8中的ConcurrentHashMap使用及場景分析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • 帶你入門Java的方法

    帶你入門Java的方法

    這篇文章主要介紹了java基礎之方法詳解,文中有非常詳細的代碼示例,對正在學習java基礎的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-07-07
  • Java實現(xiàn)map轉換成json的方法詳解

    Java實現(xiàn)map轉換成json的方法詳解

    這篇文章主要為大家詳細介紹了Java語言實現(xiàn)map轉換成json的幾種方法,文中的示例代碼講解詳細,對我們學習Java有一定幫助,需要的可以參考一下
    2022-05-05
  • java 圖片加水印實例代碼

    java 圖片加水印實例代碼

    java 圖片加水印實例代碼,需要的朋友可以參考一下
    2013-06-06
  • spring通過構造函數(shù)注入實現(xiàn)方法分析

    spring通過構造函數(shù)注入實現(xiàn)方法分析

    這篇文章主要介紹了spring通過構造函數(shù)注入實現(xiàn)方法,結合實例形式分析了spring通過構造函數(shù)注入的原理、實現(xiàn)步驟及相關操作注意事項,需要的朋友可以參考下
    2019-10-10
  • Spring Scheduling本地任務調(diào)度設計與實現(xiàn)方式

    Spring Scheduling本地任務調(diào)度設計與實現(xiàn)方式

    這篇文章主要介紹了Spring Scheduling本地任務調(diào)度設計與實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • SpringBoot任務調(diào)度器的實現(xiàn)代碼

    SpringBoot任務調(diào)度器的實現(xiàn)代碼

    SpringBoot自帶了任務調(diào)度器,通過注解的方式使用。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • SpringCloud?集成Sentinel的實戰(zhàn)教程

    SpringCloud?集成Sentinel的實戰(zhàn)教程

    這篇文章主要介紹了SpringCloud?集成Sentinel的詳細過程,本文通過實例代碼圖文相結合給大家介紹的非常詳細,感興趣的朋友一起看看吧
    2024-08-08
  • spring利用squertz實現(xiàn)定時任務

    spring利用squertz實現(xiàn)定時任務

    spring squertz是一個強大的定時任務處理方式。下面這篇文章主要介紹了spring利用squertz實現(xiàn)定時任務的相關資料,文中介紹的很詳細,對大家具有一定的參考借鑒價值,需要的朋友們下面來一起看看吧。
    2017-01-01
  • 詳談java中File類getPath()、getAbsolutePath()、getCanonical的區(qū)別

    詳談java中File類getPath()、getAbsolutePath()、getCanonical的區(qū)別

    下面小編就為大家?guī)硪黄斦刯ava中File類getPath()、getAbsolutePath()、getCanonical的區(qū)別。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07

最新評論