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

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

 更新時(shí)間:2017年05月01日 12:21:00   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇java中棧和隊(duì)列的實(shí)現(xiàn)和API的用法(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

在java中要實(shí)現(xiàn)棧和隊(duì)列,需要用到j(luò)ava集合的相關(guān)知識(shí),特別是Stack、LinkedList等相關(guān)集合類型。

一、棧的實(shí)現(xiàn)

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

1.Stack實(shí)現(xiàn)

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

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

當(dāng)LinkedList被當(dāng)做棧來(lái)使用時(shí),常用api及對(duì)應(yīng)關(guān)系如下:

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

二、隊(duì)列的實(shí)現(xiàn)

java中雖然有Queue接口,單java并沒(méi)有給出具體的隊(duì)列實(shí)現(xiàn)類,而Java中讓LinkedList類實(shí)現(xiàn)了Queue接口,所以使用隊(duì)列的時(shí)候,一般采用LinkedList。因?yàn)長(zhǎng)inkedList是雙向鏈表,可以很方便的實(shí)現(xiàn)隊(duì)列的所有功能。

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

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

當(dāng)采用LinkedList來(lái)實(shí)現(xiàn)時(shí),api的使用和對(duì)用關(guān)系如下:

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

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

相關(guān)文章

  • JavaWeb中web.xml初始化加載順序詳解

    JavaWeb中web.xml初始化加載順序詳解

    本篇文章主要介紹了JavaWeb中web.xml初始化加載順序詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • java多線程讀取多個(gè)文件的方法

    java多線程讀取多個(gè)文件的方法

    這篇文章主要為大家詳細(xì)介紹了java多線程讀取多個(gè)文件的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-08-08
  • java網(wǎng)上圖書(shū)商城(1)User模塊

    java網(wǎng)上圖書(shū)商城(1)User模塊

    這篇文章主要介紹了java網(wǎng)上圖書(shū)商城,User模塊,實(shí)現(xiàn)用戶注冊(cè)功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • java代碼實(shí)現(xiàn)C盤(pán)文件統(tǒng)計(jì)工具

    java代碼實(shí)現(xiàn)C盤(pán)文件統(tǒng)計(jì)工具

    今天周末,給大家分享基于java代碼實(shí)現(xiàn)C盤(pán)文件統(tǒng)計(jì)工具,在這小編使用的版本是Maven-3.9.9,jdk1.8,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-07-07
  • Java利用策略模式實(shí)現(xiàn)條件判斷,告別if else

    Java利用策略模式實(shí)現(xiàn)條件判斷,告別if else

    策略模式定義了一系列算法,并且將每個(gè)算法封裝起來(lái),使得他們可以相互替換,而且算法的變化不會(huì)影響使用算法的客戶端。本文將通過(guò)案例講解如何利用Java的策略模式實(shí)現(xiàn)條件判斷,告別if----else條件硬編碼,需要的可以參考一下
    2022-02-02
  • Java接口DAO模式代碼原理及應(yīng)用詳解

    Java接口DAO模式代碼原理及應(yīng)用詳解

    這篇文章主要介紹了Java接口DAO模式代碼原理及應(yīng)用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Intellij IDEA解析jacoco結(jié)果文件的方法

    Intellij IDEA解析jacoco結(jié)果文件的方法

    這篇文章主要介紹了Intellij IDEA解析jacoco結(jié)果文件的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Java中HashMap的put過(guò)程詳解

    Java中HashMap的put過(guò)程詳解

    這篇文章主要介紹了Java中HashMap的put過(guò)程詳解,HashMap有4個(gè)構(gòu)造器,其他構(gòu)造器如果用戶沒(méi)有傳入initialCapacity?和loadFactor這兩個(gè)參數(shù),會(huì)使用默認(rèn)值一般如果new?HashMap()不傳值,需要的朋友可以參考下
    2023-07-07
  • 詳解RestTemplate的三種使用方式

    詳解RestTemplate的三種使用方式

    這篇文章主要介紹了詳解RestTemplate的三種使用方式,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-10-10
  • Idea中mapper注入報(bào)錯(cuò)問(wèn)題及解決

    Idea中mapper注入報(bào)錯(cuò)問(wèn)題及解決

    這篇文章主要介紹了Idea中mapper注入報(bào)錯(cuò)問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評(píng)論