JMV中栈的指令集架构和寄存器的指令集架构两者的区别?
JMV中栈的指令集架构和寄存器的指令集架构两者的区别
-
栈
- 设计和实现更简单一些(通过方法实现,每执行一个方法就可以理解为入栈操作,执行完出栈),适用于资源受限的系统(嵌入式、机顶盒、打印机)最初设计的时候也希望应用于资源受限的系统当中
- 避开了寄存器的分配难题:使用零地址指令分配方式
- 指令流中的指令大部分是零地址指令,其执行过程依赖于操作栈,指令集更小,编译器容易实现
- 不需要硬件支持,可移植性更好,更好实现跨平台
-
寄存器
- 典型的应用就是X86的二进制指令集,比如传统的PC以及Android的Davlik虚拟机
- 花费更少的指令去完成一项操作
- 在大部分情况下,基于寄存器架构的指令集往往都以一地址指令、二地址执行和三地址指令为主,二基于栈式架构的指令集却是以零地址指令为主。
- 缺点:指令集架构则完全依赖硬件,可移植性差
- 优点:性能优秀和执行更高效
- 优点和缺点原因都是一样的:完全基于CPU,指令需要CPU来进行执行,在高速缓冲区进行执行,速度比栈要快,但是涉及到指令由CPU来执行,跟硬件耦合度比较高。
零地址指令
- 零地址指令(零地址指令的字节码文件中每8位字节进行对齐),对应的就有一地址指令,二地址指令,三地址指令,在做地址指令去执行的时候,需要有两部分,一部分叫地址,比如地址是1,下一个是他的操作数比如3,想拿3做运算,1是地址,3是操作数,那么一地址指令是有1个地址,1个操作数,二地址指令是有2个地址,所谓零地址就指的是没有地址,只有操作数。
为什么栈式零地址呢?
- 默认大家都知道栈的结构,栈只是有一个入栈出栈的操作,只针对栈顶数据进行操作,其他数据不操作,所以不需要地址。
有任何想要讨论和学习的问题可联系我:577371067@qq.com 不足之处请大家指正。