欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java中棧和隊列的實現(xiàn)和API的用法(詳解)

 更新時間:2017年05月01日 12:21:00   投稿:jingxian  
下面小編就為大家?guī)硪黄猨ava中棧和隊列的實現(xiàn)和API的用法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

在java中要實現(xiàn)棧和隊列,需要用到java集合的相關知識,特別是Stack、LinkedList等相關集合類型。

一、棧的實現(xiàn)

棧的實現(xiàn),有兩個方法:一個是用java本身的集合類型Stack類型;另一個是借用LinkedList來間接實現(xiàn)Stack。

1.Stack實現(xiàn)

直接用Stack來實現(xiàn)非常方便,常用的api函數(shù)如下:

boolean        isEmpty() // 判斷當前棧是否為空
synchronized E        peek() //獲得當前棧頂元素
synchronized E        pop() //獲得當前棧頂元素并刪除
             E        push(E object) //將元素加入棧頂
synchronized int      search(Object o)  //查找元素在棧中的位置,由棧低向棧頂方向數(shù)2.LinkedList實現(xiàn)
LinkedList 是一個繼承于AbstractSequentialList的雙向鏈表。它也可以被當作堆棧、隊列或雙端隊列進行操作。
LinkedList 實現(xiàn) List 接口,能對它進行隊列操作。
LinkedList 實現(xiàn) Deque 接口,即能將LinkedList當作雙端隊列使用。

當LinkedList被當做棧來使用時,常用api及對應關系如下:

棧方法        等效方法
push(e)      addFirst(e)
pop()        removeFirst()
peek()       peekFirst()      isEmpty()  //判斷是否為空

二、隊列的實現(xiàn)

java中雖然有Queue接口,單java并沒有給出具體的隊列實現(xiàn)類,而Java中讓LinkedList類實現(xiàn)了Queue接口,所以使用隊列的時候,一般采用LinkedList。因為LinkedList是雙向鏈表,可以很方便的實現(xiàn)隊列的所有功能。

Queue使用時要盡量避免Collection的add()和remove()方法,而是要使用offer()來加入元素,使用poll()來獲取并移出元素。它們的優(yōu)點是通過返回值可以判斷成功與否,add()和remove()方法在失敗的時候會拋出異常。 如果要使用前端而不移出該元素,使用element()或者peek()方法。

java中定義隊列 一般這樣定義: Queue<E> queue = new LinkedList<E>();

當采用LinkedList來實現(xiàn)時,api的使用和對用關系如下:

隊列方法       等效方法
offer(e)      offer(e)/offerLast(e)  //進隊列,將元素加入隊列末尾
poll()        poll()/pollFirst()  //獲取隊列頭的元素并移除
peek()        peek()/peekFirst()  //獲取隊列頭的元素       isEmpty() //判斷是否為空

以上這篇java中棧和隊列的實現(xiàn)和API的用法(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Java語言中的數(shù)據(jù)類型及其用途詳解

    Java語言中的數(shù)據(jù)類型及其用途詳解

    這篇文章主要介紹了Java語言中的數(shù)據(jù)類型及其用途,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • 解析iReport自定義行數(shù)分頁的操作方法

    解析iReport自定義行數(shù)分頁的操作方法

    ireport默認都是自動分頁數(shù)據(jù)超出頁面長度就會自動分到下一頁,但有時候業(yè)務需要一頁只顯示固定幾行這時候就需要自定義條數(shù)了。下面看具體操作吧
    2021-10-10
  • springboot中項目啟動時實現(xiàn)初始化方法加載參數(shù)

    springboot中項目啟動時實現(xiàn)初始化方法加載參數(shù)

    這篇文章主要介紹了springboot中項目啟動時實現(xiàn)初始化方法加載參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • Java實現(xiàn)讀取文章中重復出現(xiàn)的中文字符串

    Java實現(xiàn)讀取文章中重復出現(xiàn)的中文字符串

    本文主要介紹了Java實現(xiàn)讀取文章中重復出現(xiàn)的中文字符串的方法。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • Java如何實現(xiàn)雙向鏈表功能

    Java如何實現(xiàn)雙向鏈表功能

    雙向鏈表也叫雙鏈表,是鏈表的一種,它的每個數(shù)據(jù)結點中都有兩個指針,分別指向直接后繼和直接前驅(qū)。所以,從雙向鏈表中的任意一個結點開始,都可以很方便地訪問它的前驅(qū)結點和后繼結點。一般我們都構造雙向循環(huán)鏈表
    2021-11-11
  • JDK1.7以上javaFTP上傳刪除文件的實現(xiàn)方法

    JDK1.7以上javaFTP上傳刪除文件的實現(xiàn)方法

    下面小編就為大家分享一篇JDK1.7以上javaFTP上傳刪除文件的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11
  • 深入分析JAVA 建造者模式

    深入分析JAVA 建造者模式

    這篇文章主要介紹了JAVA 建造者模式的的相關資料,文中講解非常詳細,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-06-06
  • springmvc不進入Controller導致404的問題

    springmvc不進入Controller導致404的問題

    這篇文章主要介紹了springmvc不進入Controller導致404的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • SpringBoot項目打包發(fā)布到外部tomcat(出現(xiàn)各種異常的解決)

    SpringBoot項目打包發(fā)布到外部tomcat(出現(xiàn)各種異常的解決)

    這篇文章主要介紹了SpringBoot項目打包發(fā)布到外部tomcat(出現(xiàn)各種異常的解決),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • Spring?Security如何為用戶示例添加角色詳解

    Spring?Security如何為用戶示例添加角色詳解

    目前我正在用Java開發(fā)一個基于Spring Boot的web應用程序,下面這篇文章主要給大家介紹了關于Spring?Security如何為用戶示例添加角色的相關資料,需要的朋友可以參考下
    2022-10-10

最新評論