第三章总结

 

内存中字的存储

由于内存单元是字节单元,则一个字要用两个地址连续的内存单元来存放。

那么就提出了字单元的概念:由两个地址连续的内存单元组成,高地址内存单元中存放字型数据的高位字节,低地址内存单元中存放字型数据的低位字节。

DS和【address】、字的传送

在8086pc中,内存地址由段地址和偏移地址组成。

mov a1,【0】 →内存单元地址

      ↑          

      寄存器名

使用mov指令,可以完成两种传送:

1:将数据直接送入寄存器

2:将一个寄存器中的内容送入另一个寄存器

“[...]”表示一个内存单元,“[...]”中的数据0表示内存单元的偏移地址。只有偏移地址是不能定位一个内存单元

8086cpu不支持将数据直接送入段寄存器的操作。

只要在mov指令中给出16位的寄存器就可以进行16位数据的传送了。

mov、add、sub指令

它们都带有两个操作对象。

1、8086cpu内部有寄存器到段寄存器的通路,也有“mov 寄存器,段寄存器”这一相反的通路。

2、有“mov 内存单元,寄存器”也有“mov 寄存器,内存单元”

    mov ax,1000H

    mov ds,ax

    mov【0】,cs

3、“mov 段寄存器,内存单元”也可行。

mov ax,1000H

mov ds,ax

mov ds,[0]

栈本质上是一段内存空间

只能在一端进出,先进后出,后进先出

栈的两个概念:栈底、栈顶

栈底固定不动,栈顶的元素总是最后入栈,需要出栈时,又最先被从栈中取出

入栈是将一个新的元素放到栈顶,出栈是从栈顶取出一个元素

栈顶的段地址存放在SS(段寄存器)中,栈顶的偏移地址存放在SP(寄存器)中

任意时刻SS:SP指向栈顶元素

SS*16+SP 可得栈顶的物理地址

栈为空时,就相当于唯一的元素出栈,出栈sp=sp+2,入栈是减2

操作对象不能是常数

pop寄存器中,段寄存器不能是CS和SS

栈的越界问题

以下两种情形出现时会发生栈顶越界问题:

1、栈满的时候,再使用push指令入栈

2、栈空的时候,再使用pop指令出栈

8086cpu不保证我们对栈的操作不会越界

转载于:https://www.cnblogs.com/zongtianqi/p/9925324.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值