资讯专栏INFORMATION COLUMN

Java集合Stack源码深入解析

edgardeng / 2145人阅读

概要

学完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的继承关系

</>复制代码

  1. java.lang.Object
  2. java.util.AbstractCollection
  3. java.util.AbstractList
  4. java.util.Vector
  5. java.util.Stack
  6. public class Stack extends Vector {}
Stack和Collection的关系如下图:

Stack的构造函数

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

</>复制代码

  1. Stack()
Stack的API

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

</>复制代码

  1. boolean empty()
  2. synchronized E peek()
  3. synchronized E pop()
  4. E push(E object)
  5. synchronized int search(Object o)

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

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

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

</>复制代码

  1. package java.util;
  2. public
  3. class Stack extends Vector {
  4. // 版本ID。这个用于版本升级控制,这里不须理会!
  5. private static final long serialVersionUID = 1224463164541339165L;
  6. // 构造函数
  7. public Stack() {
  8. }
  9. // push函数:将元素存入栈顶
  10. public E push(E item) {
  11. // 将元素存入栈顶。
  12. // addElement()的实现在Vector.java中
  13. addElement(item);
  14. return item;
  15. }
  16. // pop函数:返回栈顶元素,并将其从栈中删除
  17. public synchronized E pop() {
  18. E obj;
  19. int len = size();
  20. obj = peek();
  21. // 删除栈顶元素,removeElementAt()的实现在Vector.java中
  22. removeElementAt(len - 1);
  23. return obj;
  24. }
  25. // peek函数:返回栈顶元素,不执行删除操作
  26. public synchronized E peek() {
  27. int len = size();
  28. if (len == 0)
  29. throw new EmptyStackException();
  30. // 返回栈顶元素,elementAt()具体实现在Vector.java中
  31. return elementAt(len - 1);
  32. }
  33. // 栈是否为空
  34. public boolean empty() {
  35. return size() == 0;
  36. }
  37. // 查找“元素o”在栈中的位置:由栈底向栈顶方向数
  38. public synchronized int search(Object o) {
  39. // 获取元素索引,elementAt()具体实现在Vector.java中
  40. int i = lastIndexOf(o);
  41. if (i >= 0) {
  42. return size() - i;
  43. }
  44. return -1;
  45. }
  46. }

总结:

(01) Stack实际上也是通过数组去实现的。

</>复制代码

  1. 执行`push`时(即,**将元素推入栈中**),是通过将元素追加的数组的末尾中。
  2. 执行`peek`时(即,**取出栈顶元素,不执行删除**),是返回数组末尾的元素。
  3. 执行`pop`时(即,**取出栈顶元素,并将该元素从栈中删除**),是取出数组末尾的元素,然后将该元素从数组中删除。

(02) Stack继承于Vector,意味着Vector拥有的属性和功能,Stack都拥有。

第3部分 Vector示例

下面我们通过实例学习如何使用Stack

</>复制代码

  1. import java.util.Stack;
  2. import java.util.Iterator;
  3. import java.util.List;
  4. /**
  5. * @desc Stack的测试程序。测试常用API的用法
  6. *
  7. * @author skywang
  8. */
  9. public class StackTest {
  10. public static void main(String[] args) {
  11. Stack stack = new Stack();
  12. // 将1,2,3,4,5添加到栈中
  13. for(int i=1; i<6; i++) {
  14. stack.push(String.valueOf(i));
  15. }
  16. // 遍历并打印出该栈
  17. iteratorThroughRandomAccess(stack) ;
  18. // 查找“2”在栈中的位置,并输出
  19. int pos = stack.search("2");
  20. System.out.println("the postion of 2 is:"+pos);
  21. // pup栈顶元素之后,遍历栈
  22. stack.pop();
  23. iteratorThroughRandomAccess(stack) ;
  24. // peek栈顶元素之后,遍历栈
  25. String val = (String)stack.peek();
  26. System.out.println("peek:"+val);
  27. iteratorThroughRandomAccess(stack) ;
  28. // 通过Iterator去遍历Stack
  29. iteratorThroughIterator(stack) ;
  30. }
  31. /**
  32. * 通过快速访问遍历Stack
  33. */
  34. public static void iteratorThroughRandomAccess(List list) {
  35. String val = null;
  36. for (int i=0; i
  37. 运行结果:

  38. </>复制代码

    1. 1 2 3 4 5
    2. the postion of 2 is:4
    3. 1 2 3 4
    4. peek:4
    5. 1 2 3 4
    6. 1 2 3 4
  39. </>复制代码

    1. 出处:http://www.cnblogs.com/skywan...

      文章有不当之处,欢迎指正,你也可以关注我的微信公众号:好好学java,获取优质学习资源。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/69399.html

相关文章

  • java源码

    摘要:集合源码解析回归基础,集合源码解析系列,持续更新和源码分析与是两个常用的操作字符串的类。这里我们从源码看下不同状态都是怎么处理的。 Java 集合深入理解:ArrayList 回归基础,Java 集合深入理解系列,持续更新~ JVM 源码分析之 System.currentTimeMillis 及 nanoTime 原理详解 JVM 源码分析之 System.currentTimeMi...

    Freeman 评论0 收藏0
  • 我的阿里之路+Java面经考点

    摘要:我的是忙碌的一年,从年初备战实习春招,年三十都在死磕源码,三月份经历了阿里五次面试,四月顺利收到实习。因为我心理很清楚,我的目标是阿里。所以在收到阿里之后的那晚,我重新规划了接下来的学习计划,将我的短期目标更新成拿下阿里转正。 我的2017是忙碌的一年,从年初备战实习春招,年三十都在死磕JDK源码,三月份经历了阿里五次面试,四月顺利收到实习offer。然后五月怀着忐忑的心情开始了蚂蚁金...

    姘搁『 评论0 收藏0
  • 一文掌握关于Java数据结构所有知识点(欢迎一起完善)

    摘要:是栈,它继承于。满二叉树除了叶结点外每一个结点都有左右子叶且叶子结点都处在最底层的二叉树。没有键值相等的节点。这是数据库选用树的最主要原因。 在我们学习Java的时候,很多人会面临我不知道继续学什么或者面试会问什么的尴尬情况(我本人之前就很迷茫)。所以,我决定通过这个开源平台来帮助一些有需要的人,通过下面的内容,你会掌握系统的Java学习以及面试的相关知识。本来是想通过Gitbook的...

    keithxiaoy 评论0 收藏0
  • ArrayList源码解析之fail-fast机制深入理解

    摘要:当多个线程对同一个集合的内容进行操作时,就可能会产生事件。当某一个线程遍历的过程中,的内容被另外一个线程所改变了就会抛出异常,产生事件。在线程在遍历过程中的某一时刻,线程执行了,并且线程删除了中的节点。 概要 前面,我们已经学习了ArrayList。接下来,我们以ArrayList为例,对Iterator的fail-fast机制进行了解。 1 fail-fast简介 fail-fast...

    NikoManiac 评论0 收藏0
  • 【修炼内功】[JVM] 类文件结构

    摘要:本文已收录修炼内功跃迁之路学习语言的时候,需要在不同的目标操作系统上或者使用交叉编译环境,使用正确的指令集编译成对应操作系统可运行的执行文件,才可以在相应的系统上运行,如果使用操作系统差异性的库或者接口,还需要针对不同的系统做不同的处理宏的 本文已收录【修炼内功】跃迁之路 showImg(https://segmentfault.com/img/bVbtpPd?w=2065&h=11...

    Eminjannn 评论0 收藏0

发表评论

0条评论

edgardeng

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<