《汇编语言》王爽 读书笔记之二内存访问

1.物理地址

CPU要访存内存单元时,要给出内存单元的地址。所有的内存单元组成的存储空间是个一维的线性空间,每一个内存单元在这个空间中都有唯一的地址,我们将这个唯一的地址称为物理地址。
CPU通过地址总线送入存储器的,必须是物理地址。因此CPU在向地址总线送地址之前,必须要在内部先形成这个物理地址。不同的CPU可以有不同的形成物理地址的方式。

8086CPU为16位结构,也就是:
运算器一次最多可处理16位数据
寄存器最大宽度为16位
寄存器和运算器之间的数据通路为16位

而8086CPU有20位地址总线,达到1M的寻址能力。面对16位结构与20位地址线的冲突,8086地址加法器采用“物理地址=段地址X16+偏移地址”的方法。其本质含义是CPU在访问内存时,用一个基础地址(段地址X16)和一个相对于基础地址的偏移地址相加给出内存单元的物理地址。

注意,内存并没有分段,段的划分来自于CPU,由于8086使用物理地址=段地址X16+偏移地址的方法给出内存单元的物理地址,使得我们可以使用分段的方式来管理内存。在编程时,可根据需要,将若干连续的内存单元看做一个段,用段地址X16定位段的起始地址(基础地址),用偏移地址定位段中的内存单元。

注意:1,段的起始地址一定是16的倍数。
2,偏移地址为16位,16位的寻址能力为64KB,所以一个段的最大长度为64KB。

2.段寄存器

内存单元的段地址由段寄存器提供。

1.CS与IP 以及指令段

CS寄存器

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值