网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

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源码详解-创新互联
当前链接:http://bjjierui.cn/article/didhgp.html

其他资讯