栈是在数据结构中比较常见的一种形式,栈是采用典型的先进后出的操作方式完成的。
栈是采用先进后出的数据存储方式,每一个栈都包含一个栈顶,每次出栈是将栈顶的数据取出
data:image/s3,"s3://crabby-images/cf7e7/cf7e70145eab20e5c61d0f0c088c3c112440d408" alt=""
在java中使用Stack类进行栈的操作,Stack类是Vector的子类,Stack的定义如下
public class Stack<E>extends Vector<E>
data:image/s3,"s3://crabby-images/75e04/75e0435c91763a7cb8046a7b4a88e9f20f7e5fa7" alt=""
事例
package com.qn.test;
import java.util.Stack;
public class StackTest {
public static void main(String[] args) {
Stack<String> s=new Stack<String>();
s.push("A");//入栈
s.push("B");//入栈
s.push("C");//入栈
s.push("D");//入栈
System.out.println(s.pop());//先进后出
System.out.println(s.pop());//先进后出
System.out.println(s.pop());//先进后出
System.out.println(s.pop());//先进后出
}
}
结果
data:image/s3,"s3://crabby-images/a3ea0/a3ea052a92b5f1452b3697181ded5114f16ec726" alt=""
如果栈中没有内容了,则无法继续出栈
如下
package com.qn.test;
import java.util.Stack;
public class StackTest {
public static void main(String[] args) {
Stack<String> s=new Stack<String>();
s.push("A");//入栈
s.push("B");//入栈
s.push("C");//入栈
s.push("D");//入栈
System.out.println(s.pop());//先进后出
System.out.println(s.pop());//先进后出
System.out.println(s.pop());//先进后出
System.out.println(s.pop());//先进后出
System.out.println(s.pop());//先进后出
}
}
会出下面的空栈异常
data:image/s3,"s3://crabby-images/b2fde/b2fde53fff56b6512b7320a3dd33e7665df415c5" alt=""