快速了解指令系统

先来看看指令系统在计算机中的位置:
在这里插入图片描述

机器指令:

指令的格式:
指令要进行操作,所以用操作码来进行实现,那么对谁进行操作呢?由地址码来实现,为了编程方便,在指令集当中,往往有多种寻址方式。
操作码—地址码—寻址方式

指令字长(一条指令的长度)
固定字长,可变字长

指令的一般格式
操作码字段–地址码字段
操作码:指出进行什么操作
(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:结果的地址
A4:下一条指令的地址
(A1)OP(A2)->A3
上面我们一共做了4次访存。第一次是访存操作码,第二次是访存A1,第3次访存A2,第4次访存A3.
设我们的指令字长是32位,操作码8位,那么计算可以知道地址码的位数都是6位,那么这个时候我们会发现我们的寻址范围是2的6次方=

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值