数据结构学习笔记:栈的基础知识总结

程序员在面试中,关于如何理解栈和堆这两种数据结构的问题,也经常会被问到。那么如何回答这个问题呢?

根据个人目前理解,可从几个方面进行回答:

  1. 突出两者存取数据方式的区别,栈结构存放数据是先进后出,后进先出。堆容器存放数据类似于向罐子里扔东西,是随意的,存放东西时会产生一个内存地址,赋值给引用变量。获取数据时,通过这个地址可以查找到对应的内容。
  2. 可引入java内存结构进行回答,java内存可分为五个部分:栈内存,堆内存,方法区,本地方法区和寄存器。寄存器属于硬件设备,这里先不讨论;本地方法区存放安装的操作系统在java程序运行时用到的方法;方法区用于加载类当中的针对每个对象共有的函数和静态数据,栈内存用于存放正在运行的函数生成的基本数据和引用数据地址,简称用于存放变量;堆内存中存放由关键字new生成的对象,数组和集合等容器。
  3. 可从java源码分析,在java底层中包括stack容器存放数据,正采用了栈结构存放数据的特点。以下我通过对源码分析,简述栈的创建和应用。

栈的创建

栈是限定仅在表尾进行插入和删除操作的线性表。允许插入和删除的一端称为栈顶,另一端称为栈底,不含任何数据元素的栈称为空栈。栈又称为后进先出的线性表,简称LIFO结构。

创建栈结构代码如下:

public class Stack {
	public Node head;
	public Node current;
	/**
	 * @des 入栈操作
	 * */
	public void push(int data) {
		if (head == null) {
			head = new Node(data);
			current = head;
		} else {
			Node node = new Node(data);
			node.pre = current; //current结点作为前驱
			current = node; // current结点永远指向新添加的那个结点
		}
	}
	/**
	 * @des 出栈操作
	 * */
	public Node pop(){
		if (current == null) 
			return null;
		Node node = current; //current结点为出栈结点
		current = current.pre; // 每出栈一个结点后,current后退一位
		return node;
		
	}
	class Node{
		int data;
		Node pre; // 需要知道当前结点前一个结点
		public Node(int data){
			this.data = data;
		}
	}
	public static void main(String[] args) {
		Stack stack = new Stack();
		stack.push(1);
		stack.push(2);
		stack.push(3);
		//打印发现,先进入的最后出栈,后进入的先出栈
		System.out.println(stack.pop().data);
		System.out.println(stack.pop().data);
		System.out.println(stack.pop().data);
	}
}

栈的应用-递归

把一个直接调用自己或通过一系列的调用语句间接的调用自己的函数,称之为递归函数。

迭代和递归的区别是:迭代使用的是循环结构,递归使用的是选择结构。递归能使程序的结构更清晰,更简洁,更好理解。但大量的递归调用会建立函数的副本,会耗费大量时间和内存。迭代不需要反复调用函数和占用额外的内存。要视情况选择实现方式。

安卓开发与栈相关知识点:

关于activity任务栈的知识点,点击链接即可查看大神具体讲解,关于fragment管理栈的知识点,点击链接即可查看具体讲解。既然有非常详细的分析论述,这里我就不赘述了,大家可以自己查看分析。

感谢您的阅读~

你可能感兴趣的:(数据结构学习笔记)