前置知识
阅读本文需要对以下知识有所了解:
* 栈
* 汇编
* Java 基础
* 逆波兰表达式(有学过的同学阅读本文毫无障碍)
引子
基于寄存器的设计模式
就我们所熟知的x86或arm指令集来说,其对数据的操作都是基于寄存器。例如,要对两个数执行加法操作则需要将这两个数分别送入两个寄存器再执行加法操作,这也符合我们对于编程语言认知,更加易于理解。
基于栈的设计模式
基于栈的设计模式则是将数据存放在栈中,在需要使用的时候将栈顶的数据出栈,并执行相应的操作。
举例来说,在JVM中 执行 a = b + c 的字节码执行过程中操作数栈以及局部变量表的变化如下图所示。
局部变量表中存储着a、b、c 三个局部变量,首先将b和c分别入栈
将栈顶的两个数出栈执行加法操作,并将结果保存至栈顶,之后将栈顶的数出栈赋值给a
一个简单的例子
在上一节中我们了解了栈与局部变量表是如何配合完成一次加法操作的,这一节我们将对局部变量表进行深入的研究。