根据您的需要,您可能需要ArrayDeque
或LinkedList
。
两者都执行Deque
(双端队列)。
来自Javadoc ArrayDeque
:“当用作堆栈时,该类可能比Stack快,并且在用作队列时比LinkedList快。
元素可以从Deque
的任一端添加或删除。
甲Deque
可以通过调用addLast
和removeFirst
用作队列,并且也可以通过堆叠使用addLast
和removeLast
使用。
如果你真的想表现得像任何一个,你可以保持一个布尔标志,写辅助方法,或者你可以写一个类:
public class QueueOrStack<E> implements Iterable<E> {
private Deque<E> container = new ArrayDeque<E>();
private boolean isQueue;
public QueueOrStack(boolean isQueue) {
this.isQueue = isQueue;
}
public E pop() {
return isQueue ? container.removeFirst() : container.removeLast();
}
public void push(E element) {
container.addLast(element);
}
public void pushAll(E... element) {
for (E e : element)
container.addLast(e);
}
public boolean isQueue() {
return isQueue;
}
public void setQueue(boolean isQueue) {
this.isQueue = isQueue;
}
public boolean toggleQueue() {
return isQueue = !isQueue;
}
@Override
public Iterator<E> iterator() {
return container.iterator();
}
}
这里的测试:
QueueOrStack<String> strings = new QueueOrStack<>(true);
strings.pushAll("hello", ", " , "world\n");
for(String s : strings)
System.out.print(s); //"hello, world"
System.out.println(strings.pop()); //"hello"
strings.toggleQueue();
System.out.println(strings.pop()); //"world"
为什么不'java.util.Queue'和'java.util.Stack '为你工作? –
Moira
它必须是Something <>的一个变量,它可以存储 –