⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 stack.java

📁 EffectiveJava
💻 JAVA
字号:
// Page 47

import java.util.*;

public class Stack implements Cloneable {
    private Object[] elements;
    private int size = 0;

    public Stack(int initialCapacity) {
        this.elements = new Object[initialCapacity];
    }

    public void push(Object e) {
        ensureCapacity();
        elements[size++] = e;
    }

    public Object pop() {
        if (size == 0)
            throw new EmptyStackException();
        Object result = elements[--size];
        elements[size] = null; // Eliminate obsolete reference
        return result;
    }

    // Ensure space for at least one more element.
    private void ensureCapacity() {
        if (elements.length == size) {
            Object oldElements[] = elements;
            elements = new Object[2 * elements.length + 1];
            System.arraycopy(oldElements, 0, elements, 0, size);
        }
    }

/* COMMENTED OUT

    // Won't work for this class!! (page 47)
    public Object clone() throws CloneNotSupportedException {
        return super.clone();
    }

*/

    public Object clone() throws CloneNotSupportedException {
        Stack result = (Stack) super.clone();
        result.elements = (Object[]) elements.clone();
        return result;
    }

    public static void main(String[] args) {
        Stack s = new Stack(0);
        for (int i=0; i<args.length; i++)
            s.push(args[i]);

        Stack s2 = null;
        try {
            s2 = (Stack) s.clone();
        } catch(CloneNotSupportedException e) {
            throw new Error("Assertion failure");  // Can't happen
        }

        for (int i=0; i<args.length; i++)
            System.out.print(s.pop()+" ");
        System.out.println();

        for (int i=0; i<args.length; i++)
            System.out.print(s2.pop()+" ");
        System.out.println();
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -