blob: dcc62d34af2f4e6a8c1bfcfa351a24ec53b2ccf5 [file] [log] [blame]
/*
* Copyright 2007 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package java.util;
/**
* Maintains a last-in, first-out collection of objects. <a
* href="http://java.sun.com/j2se/1.5.0/docs/api/java/util/Stack.html">[Sun
* docs]</a>
*
* @param <E> element type.
*/
public class Stack<E> extends Vector<E> {
@Override
public Object clone() {
Stack<E> s = new Stack<E>();
s.addAll(this);
return s;
}
public boolean empty() {
return isEmpty();
}
public E peek() {
int sz = size();
if (sz > 0) {
return get(sz - 1);
} else {
throw new EmptyStackException();
}
}
public E pop() {
int sz = size();
if (sz > 0) {
return remove(sz - 1);
} else {
throw new EmptyStackException();
}
}
public E push(E o) {
add(o);
return o;
}
public int search(Object o) {
int pos = lastIndexOf(o);
if (pos >= 0) {
return size() - pos;
}
return -1;
}
}