java中棧和隊(duì)列的實(shí)現(xiàn)和API的用法(詳解)
在java中要實(shí)現(xiàn)棧和隊(duì)列,需要用到j(luò)ava集合的相關(guān)知識(shí),特別是Stack、LinkedList等相關(guān)集合類(lèi)型。
一、棧的實(shí)現(xiàn)
棧的實(shí)現(xiàn),有兩個(gè)方法:一個(gè)是用java本身的集合類(lèi)型Stack類(lèi)型;另一個(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)類(lèi),而Java中讓LinkedList類(lèi)實(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)文章
Java語(yǔ)言中的數(shù)據(jù)類(lèi)型及其用途詳解
這篇文章主要介紹了Java語(yǔ)言中的數(shù)據(jù)類(lèi)型及其用途,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04
解析iReport自定義行數(shù)分頁(yè)的操作方法
ireport默認(rèn)都是自動(dòng)分頁(yè)數(shù)據(jù)超出頁(yè)面長(zhǎng)度就會(huì)自動(dòng)分到下一頁(yè),但有時(shí)候業(yè)務(wù)需要一頁(yè)只顯示固定幾行這時(shí)候就需要自定義條數(shù)了。下面看具體操作吧2021-10-10
springboot中項(xiàng)目啟動(dòng)時(shí)實(shí)現(xiàn)初始化方法加載參數(shù)
這篇文章主要介紹了springboot中項(xiàng)目啟動(dòng)時(shí)實(shí)現(xiàn)初始化方法加載參數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
Java實(shí)現(xiàn)讀取文章中重復(fù)出現(xiàn)的中文字符串
本文主要介紹了Java實(shí)現(xiàn)讀取文章中重復(fù)出現(xiàn)的中文字符串的方法。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03
JDK1.7以上javaFTP上傳刪除文件的實(shí)現(xiàn)方法
下面小編就為大家分享一篇JDK1.7以上javaFTP上傳刪除文件的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
springmvc不進(jìn)入Controller導(dǎo)致404的問(wèn)題
這篇文章主要介紹了springmvc不進(jìn)入Controller導(dǎo)致404的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
SpringBoot項(xiàng)目打包發(fā)布到外部tomcat(出現(xiàn)各種異常的解決)
這篇文章主要介紹了SpringBoot項(xiàng)目打包發(fā)布到外部tomcat(出現(xiàn)各種異常的解決),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
Spring?Security如何為用戶(hù)示例添加角色詳解
目前我正在用Java開(kāi)發(fā)一個(gè)基于Spring Boot的web應(yīng)用程序,下面這篇文章主要給大家介紹了關(guān)于Spring?Security如何為用戶(hù)示例添加角色的相關(guān)資料,需要的朋友可以參考下2022-10-10

