在java中要實現棧和隊列,需要用到java集合的相關知識,特別是Stack、LinkedList等相關集合類型。
一、棧的實現
棧的實現,有兩個方法:一個是用java本身的集合類型Stack類型;另一個是借用LinkedList來間接實現Stack。
1.Stack實現
直接用Stack來實現非常方便,常用的api函數如下:
boolean isEmpty() // 判斷當前棧是否為空
synchronized E peek() //獲得當前棧頂元素
synchronized E pop() //獲得當前棧頂元素并刪除
E push(E object) //將元素加入棧頂
synchronized int search(Object o) //查找元素在棧中的位置,由棧低向棧頂方向數2.LinkedList實現
LinkedList 是一個繼承于AbstractSequentialList的雙向鏈表。它也可以被當作堆棧、隊列或雙端隊列進行操作。
LinkedList 實現 List 接口,能對它進行隊列操作。
LinkedList 實現 Deque 接口,即能將LinkedList當作雙端隊列使用。
當LinkedList被當做棧來使用時,常用api及對應關系如下:
棧方法 等效方法
push(e) addFirst(e)
pop() removeFirst()
peek() peekFirst() isEmpty() //判斷是否為空
二、隊列的實現
java中雖然有Queue接口,單java并沒有給出具體的隊列實現類,而Java中讓LinkedList類實現了Queue接口,所以使用隊列的時候,一般采用LinkedList。因為LinkedList是雙向鏈表,可以很方便的實現隊列的所有功能。
Queue使用時要盡量避免Collection的add()和remove()方法,而是要使用offer()來加入元素,使用poll()來獲取并移出元素。它們的優點是通過返回值可以判斷成功與否,add()和remove()方法在失敗的時候會拋出異常。 如果要使用前端而不移出該元素,使用element()或者peek()方法。
java中定義隊列 一般這樣定義: Queue<E> queue = new LinkedList<E>();
當采用LinkedList來實現時,api的使用和對用關系如下:
隊列方法 等效方法
offer(e) offer(e)/offerLast(e) //進隊列,將元素加入隊列末尾
poll() poll()/pollFirst() //獲取隊列頭的元素并移除
peek() peek()/peekFirst() //獲取隊列頭的元素 isEmpty() //判斷是否為空
以上這篇java中棧和隊列的實現和API的用法(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。