前言
集合源码分析系列:Java集合源码分析
前面已经把Vector
,ArrayList
,LinkedList
分析完了,本来是想开始Map
这一块,但是看了下面这个接口设计框架图:整个接口框架关系如下(来自百度百科):
原来还有一个漏网之鱼,Stack
栈的是挂在Vector
下,前面我们已经分析过Vector
了,那么顺便把Stack
分析一遍。再不写就2022年了:
Stack介绍
栈是一种数据结构,并不是Java
特有的,在Java
里面体现是Stack
类。它的本质是先进后出,就像是一个桶,只能不断的放在上面,取出来的时候,也只能不断的取出最上面的数据。要想取出底层的数据,只有等到上面的数据都取出来,才能做到。当然,如果有这种需求,我们一般会使用双向队列。
以下是栈的特性演示:
Stack
在Java
中是继承于Vector
,这里说的是1.8
版本,共用了Vector
底层的数据结构,底层都是使用数组实现的,具有以下的特点:
- 先进后出(``FILO`)
- 继承于
Vector</