二、指令系统集结构的分类(识记)
前面我们知道了指令系统的设计要确定它的指令格式、类型、操作及对操作数的访问方式。现在就提到了分类:
一般地,指令系统集结构分类主要是依据在CPU中以何种存储方式来存放操作数。
我们知到,CPU在进行数据计算时,总是要先把数据取到某种寄存器中才能开始。而这寄存器的类型有堆栈型、累加器型和通用寄存器型三种。相应地,使用哪种存储方式来存放操作数的,就把指令系统集结构分成堆栈型、累加器型和通用寄存器型三类。它们是有区别的,堆栈型结构中,操作数总是被默认存放在栈顶,累加器结构中,操作数总是被默认存放在累加器中;而在通用寄存器中,所有的操作数都必须被说明是存放在哪一个寄存器或存储器的哪个单元中。
所有的计算机都可按上述分类标准进行归类。但有的机器可能是某些类型的混合,如intel的8086处理器便是通用寄存器结构和累加器结构的混合。
三种类型的比较:
其中通用寄存器指令系统又可进一步分为:寄存器-寄存器、寄存器-存储器以及存储器-存储器三类。在RISC机中,只可能存在寄存器-寄存器类型。(寄存器是在计算机内部的存储小容量数据的装置,尤指数据可以同时存储和运算的装置)请注意它们的优缺点,第一种是具有最好的指令密度,但是访存速度慢。第三种方式则简单,但程序代码较长。第二种取中。