高级程序设计语言生成的中间代码一般有两种:基于栈的和基于寄存器的。 一般来说,基于寄存器的实现方式比较高效,因为我们现实中的机器基本上都是使用基于寄存器的指令集,所以从高级语言映射到机器码会相对容易和高效。但是采用基于寄存器的方式,完成同一
高级程序设计语言生成的中间代码一般有两种:基于栈的和基于寄存器的。
一般来说,基于寄存器的实现方式比较高效,因为我们现实中的机器基本上都是使用基于寄存器的指令集,所以从高级语言映射到机器码会相对容易和高效。但是采用基于寄存器的方式,完成同一个命令,需要使用较多的指令,实现上会比较复杂。
Red也是使用了基于栈的方式来实现运行时的。下面的PPT展示了各个操作的执行过程。
PPT: Red Call Stack (可能需翻墙,这应该难不倒作为程序员的聪明的你吧!)