汇编学习笔记(三)

本文是8086CPU的汇编学习笔记,介绍了8086CPU的16位结构、20位寻址方式,以及段寄存器的作用。详细讲解了CS和IP如何指导指令执行,DS段寄存器在读写内存时的作用。同时,讨论了`mov`, `add`, `sub`指令的用法,以及栈操作中的SS和SP寄存器,强调了栈顶溢出问题的重要性。" 72961457,1325240,Android RenderScript SIGSEGV崩溃分析,"['Android开发', '异常处理', '调试', 'RenderScript', '内存错误']
摘要由CSDN通过智能技术生成

汇编学习笔记(三)

8086CPU

8086CPU是Intel公司1978年设计的16位微处理器芯片,x86架构的鼻祖,一般学习汇编都从8086CPU开始,所以有必要搞清楚8086CPU的相关结构:

  1. 8086是16位机。16位机是指:寄存器的宽度是16位,运算器一次最多可以处理16位数据等。
  2. 8086的地址总线宽度是20位,所以最大寻址空间为:2^20B = 1MB。
  3. 8086的数据总线宽度是16位,即一次最大可以传送16bit的数据(2个字节/Byte)。

8086CPU的寻址方法

8086的地址总线是20位,但是寄存器是16位,如果地址只是简单的从内部寄存器发出,则只能发出16位地址,无法达到20位,为此,8086运用了两个16位数据的方式来给出20位的地址:

物理地址(20位) = 地址1(16位)×16 + 地址2(16位)

说明:

  1. 地址1*16,可以看成地址1左移4位,例如:
地址1 = 1110 0011 1011 1101
地址1 × 16 = 1110 0011 1011 1101 0000

可以看出16位地址1×16 后就是20位地址了,在加上一个16位地址2还是20位。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值