快速了解指令系统
先来看看指令系统在计算机中的位置: 机器指令: 指令的格式: 指令要进行操作,所以用操作码来进行实现,那么对谁进行操作呢?由地址码来实现,为了编程方便,在指令集当中,往往有多种寻址方式。 操作码—地址码—寻址方式 指令字长 (一条指令的长度) 固定字长,可变字长 指令的一般格式 操作码字段–地址码字段 操作码:指出进行什么操作 (1)长度固定 用于指令字长较长的情况,RISC 如 IBM 370 8位 (2)长度可变 操作码分散在指令集的不同字段上 (3) 扩展操作码技术 为什么要扩展操作码呢? 用上面的图来进行讲解:如果OP,A1,A2,A3都是4位的,那么这个最多只能有16条不同类型的指令,这显然是不够的,所以我们需要对操作码进行扩展。 我们经全为1的状态作为标记,如果我们的操作为1111,就扩展一位操作码,意思就是这个时候从0000-1110只有15个3地址码。相似的,如果标志位11111111,那么说明这个时候,有11110000-11111110一共有15个2地址码。剩下的分析都是相似的。 注意:3地址指令操作码每减少一个最多可构成2的4次方的2地址指令 2地址操作码每减少一个最多可以构成2的4次方的1地址指令 在程序中经常出现的那些指令我们可以用短操作码 (短的查的快呀), 那些不常出现的就用常操作码来表示。 地址码: A1:第一操作数地址 A2:第二操作数地址 A3