Stack源码分析
Posted zitai
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Stack源码分析相关的知识,希望对你有一定的参考价值。
简介
Stack是一个栈,那就满足于后进先出(FILO)。
public class Stack<E> extends Vector<E>
该类继承自Vector,即其容器的数据类型是数据,拥有Vector的特性。在Vector源码分析有详细该类信息。
构造函数:
public Stack() {}
常用API
boolean empty()
synchronized E peek()
synchronized E pop()
E push(E object)
synchronized int search(Object o)
Stack也拥有Vector的API。
源码分析(JDK1.8)
//在栈顶添加数据
public E push(E item) {
addElement(item);
return item;
}
//在栈顶删除数据并返回
public synchronized E pop() {
E obj;
int len = size();
obj = peek();
//removeElementAt在父类中有定义。
removeElementAt(len - 1);
return obj;
}
//返回栈顶数据
public synchronized E peek() {
//size在父类中有定义。
int len = size();
if (len == 0)
throw new EmptyStackException();
return elementAt(len - 1);
}
//栈是否为空
public boolean empty() {
return size() == 0;
}
//在栈顶往栈底查找数据o的索引
public synchronized int search(Object o) {
//lastIndexOf在父类中有定义。
int i = lastIndexOf(o);
if (i >= 0) {
return size() - i;
}
return -1;
}
// 版本ID
private static final long serialVersionUID = 1224463164541339165L;
总结
-
Stack是一个栈,该类通过一个数据为数据结构来实现。
-
Stack继承自Vector,拥有Vector功能和属性。
以上是关于Stack源码分析的主要内容,如果未能解决你的问题,请参考以下文章
Android 插件化VirtualApp 源码分析 ( 目前的 API 现状 | 安装应用源码分析 | 安装按钮执行的操作 | 返回到 HomeActivity 执行的操作 )(代码片段
Android 逆向整体加固脱壳 ( DEX 优化流程分析 | DexPrepare.cpp 中 dvmOptimizeDexFile() 方法分析 | /bin/dexopt 源码分析 )(代码片段
Android 事件分发事件分发源码分析 ( Activity 中各层级的事件传递 | Activity -> PhoneWindow -> DecorView -> ViewGroup )(代码片段