搜尋
首頁Javajava教程Java中棧的用法介紹(附程式碼)

Java中棧的用法介紹(附程式碼)

Mar 29, 2019 am 11:13 AM
javastack

這篇文章帶給大家的內容是關於Java中棧的用法介紹(附程式碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

Java中的Stack是早期的遺留類,Sun/Oracle已經不建議使用,現在只是為了兼容遺留代碼而保留.

遺留實現

如下面的程式碼所示,java.util.Stack中的實作是基於動態陣列實作的,而Vector同樣是被廢棄的類別。

個人看來,這個實作有兩個問題

基於Vector,需要同步因而效能損失很嚴重

基於陣列而非鍊錶,堆疊很大時需要多次擴容,帶來不必要的效能損失

public
class Stack<e> extends Vector<e> {
    /**
     * Creates an empty Stack.
     */
    public Stack() {
    }

    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;
    }

    /** use serialVersionUID from JDK 1.0.2 for interoperability */
    private static final long serialVersionUID = 1224463164541339165L;
}</e></e>

自己簡單的封裝

#下面是基於LinkedList封裝的Stack

這裡的堆疊是一個裝飾器。

import java.util.LinkedList;
import java.util.NoSuchElementException;

public class Stack<t> {
    private LinkedList<t> stack;

    Stack() {
        stack = new LinkedList();
    }

    public void push(T o) {
        stack.add(o);
    }

    public T pop() {
        if (size() <p>這篇文章到這裡就已經全部結束了,更多其他精彩內容可以關注PHP中文網的<a href="http://www.php.cn/course/list/36.html" target="_blank">Java影片教學</a>專欄! </p></t></t>

以上是Java中棧的用法介紹(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:segmentfault。如有侵權,請聯絡admin@php.cn刪除

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具