您好,登錄后才能下訂單哦!
java 集合之Stack
概要:
Stack是棧,特性是先進(jìn)后出(FILO,F(xiàn)irst In Last Out)。Stack是繼承于Vector(矢量隊列),由于Vector是同數(shù)組實(shí)現(xiàn)的,Stack也是通過數(shù)組而非鏈表。
Stack和Collection關(guān)系如下:
基于Java8的源代碼:
public class Stack<E> extends Vector<E> { public Stack() {//創(chuàng)建空棧 } public E push(E item) {//入棧 addElement(item); return item; } //出棧 public synchronized E pop() { E obj; int len = size(); obj = peek(); removeElementAt(len - 1); return obj; } //返回棧頂元素,但并不出棧 public synchronized E peek() { int len = size(); if (len == 0) throw new EmptyStackException(); return elementAt(len - 1); } //判斷棧是否為空 public boolean empty() { return size() == 0; } //查找元素并返回棧深 public synchronized int search(Object o) { int i = lastIndexOf(o); if (i >= 0) { return size() - i; } return -1; } //序列版本號 private static final long serialVersionUID = 1224463164541339165L; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。