Java集合Stack源码详解-创新互联

概要

我们提供的服务有:成都做网站、网站设计、微信公众号开发、网站优化、网站认证、罗江ssl等。为千余家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的罗江网站制作公司

学完Vector了之后,接下来我们开始学习Stack。Stack很简单,它继承于Vector。学习方式还是和之前一样,先对Stack有个整体认识,然后再学习它的源码;最后再通过实例来学会使用它。

第1部分 Stack介绍 Stack简介

Stack是栈。它的特性是:先进后出(FILO, First In Last Out)。

java工具包中的Stack是继承于Vector(矢量队列)的,由于Vector是通过数组实现的,这就意味着,Stack也是通过数组实现的,而非链表。当然,我们也可以将LinkedList当作栈来使用!在“Java 集合系列06之 Vector详细介绍(源码解析)和使用示例”中,已经详细介绍过Vector的数据结构,这里就不再对Stack的数据结构进行说明了。

Stack的继承关系

java.lang.Object
↳     java.util.AbstractCollection
   ↳     java.util.AbstractList
       ↳     java.util.Vector
           ↳     java.util.Stack

public class Stack extends Vector {}


Stack和Collection的关系如下图:

Stack的构造函数

Stack只有一个默认构造函数,如下:

Stack()
Stack的API

Stack是栈,它常用的API如下:

            boolean       empty()
synchronized E             peek()
synchronized E             pop()
             E             push(E object)
synchronized int           search(Object o)


由于Stack和继承于Vector,因此它也包含Vector中的全部API。

第2部分 Stack源码解析(基于JDK1.6.0_45)

Stack的源码非常简单,下面我们对它进行学习。

package java.util;

public
class Stack extends Vector {
 // 版本ID。这个用于版本升级控制,这里不须理会!
 private static final long serialVersionUID = 1224463164541339165L;

 // 构造函数
 public Stack() {
 }

 // push函数:将元素存入栈顶
 public E push(E item) {
  // 将元素存入栈顶。
  // addElement()的实现在Vector.java中
  addElement(item);

  return item;
 }

 // pop函数:返回栈顶元素,并将其从栈中删除
 public synchronized E pop() {
  E obj;
  int len = size();

  obj = peek();
  // 删除栈顶元素,removeElementAt()的实现在Vector.java中
  removeElementAt(len - 1);

  return obj;
 }

 // peek函数:返回栈顶元素,不执行删除操作
 public synchronized E peek() {
  int len = size();

  if (len == 0)
   throw new EmptyStackException();
  // 返回栈顶元素,elementAt()具体实现在Vector.java中
  return elementAt(len - 1);
 }

 // 栈是否为空
 public boolean empty() {
  return size() == 0;
 }

 // 查找“元素o”在栈中的位置:由栈底向栈顶方向数
 public synchronized int search(Object o) {
  // 获取元素索引,elementAt()具体实现在Vector.java中
  int i = lastIndexOf(o);

  if (i >= 0) {
   return size() - i;
  }
  return -1;
 }
}


文章题目:Java集合Stack源码详解-创新互联
URL分享:http://scyanting.com/article/didhgp.html