汇编语言(二)——寄存器(内存访问)

啦啦啦啦啦~~

第二篇汇编,话不多说,开始啦!


目录

一、内存中字的存储

二、DS和[address]

三、字的传送

四、mov、add、sub指令

五、数据段

六、栈

七、CPU提供的栈机制

八、栈顶超界的问题

九、push、pop

十、栈段


一、内存中字的存储

  • CPU 中,用16 位寄存器来存储一个字。高 8 位存放高位字节,低8位存放低位字节。在内存中存储时,由于内存单元是字节单元(一个单元存放一个字节),则一个字要用两个地址连续的内存单元来存放,这个字的低位字节存放在低地址单元中,高位字节存放在高地址单元中。

  • 字单元——即存放一个字型数据(16 位)的内存单元,由两个地址连续的内存单元组成。高地址内存单元中存放字型数据的高位字节,低地址内存单元中存放字型数据的低位字节。

  • 在以后的课程中,我们将起始地址为N的字单元简称为N 地址字单元。比如一个字单元由2、3两个内存单元组成,则这个字单元的起始地址为2,我们可以说这是2地址字单元。

二、DS和[address]

1、内存地址=段地址+偏移地址

2、DS寄存器——通常用来存放要访问数据的段地址。

例:比如我们要读取 10000H单元的内容,可以用如下的程序段进行。

                mov         bx , 1000H  ——不能直接把地址放进DS寄存器,将段地址先送进bx
               
 mov         ds , bx        ——依靠这两条固定语句完成
                mov         al  , [0]        ——[ ]的操作对象是一个内存单元,0说明偏移地址是0

(1)8086CPU自动取ds中的数据为内存单元的段地址。

(2)[address] 表示一个偏移地址为 address 的内存单元。
(3)在内存和寄存器之间传送字型数据时,高地址单元和高8位寄存器、低地址单元和低8位寄存器相对应。

三、字的传送

1、用mov指令在寄存器和内存之间进行字节型数据的传送。

     8086CPU是16位结构,有16根数据线,可以一次性传送16位的数据 = 可以一次性传送一个字。只要在 mov 指令中给出16 位的寄存器就可以进行16 位数据的传送了。

例:

        mov         bx , 1000H
        mov         ds , bx
        mov         ax , [0]         ——1000:0处的字型数据送入ax
        mov         [0] , cx         ——cx中的16位数据送到1000:0处

四、mov、add、sub指令

1、mov   寄存器名 ,内存单元地址

                mov         寄存器 ,数据            比如:mov ax  , 8
                mov         寄存器 ,寄存器         比如:mov ax , bx
                mov         寄存器 ,内存单元     比如:mov ax  , [0]
                mov         内存单元 ,寄存器     比如:mov[0]   , ax
                mov         段寄存器 ,寄存器     比如:mov ds  , ax

2、 add         寄存器 ,数据                       比如:add ax,8
       add         寄存器 ,寄存器                   比如:add ax,bx
       add         寄存器 ,内存单元                比如:add ax,[0]
       add         内存单元 ,寄存器                比如:add[0],ax
     

3、 sub         寄存器 ,数据                        比如:sub ax,9
       sub         寄存器 ,寄存器                    比如:sub ax,bx
       sub         寄存器 ,内存单元                 比如:sub ax,[0]
       sub         内存单元 ,寄存器                 比如:sub [0],ax

五、数据段

1、对于8086PC机,在编程时,可以根据需要,将一组内存单元定义为一个段。我们可以将一组长度为N(N≤64KB)、地址连续、起始地址为16的倍数的内存单元当作专门存储数据的内存空间,从而定义了一个数据段。

注:CPU中的内存都是自己定义是什么类型,比如段地址、数据、指令等。

例:用123B0H~123B9H这段内存空间来存放数据,我们就可以认为,123B0H~123B9H这段内存是一个数据段,它的段地址为123BH,长度为10个字节。

六、栈

1、在这里,我们对栈的研究仅限于这个角度:栈是一种具有特殊的访问方式的存储空间。

它的特殊性就在于,最后进入这个空间的数据,最先出去。

 2、如果说,下例中的盒子就是一个栈,我们可以看出,栈有两个基本的操作:入栈和出栈。

(1)入栈就是将一个新的元素放到栈顶。

(2)出栈就是从栈顶取出一个元素。

 

 

栈顶的元素总是最后入栈,需要出栈时,又最先被从栈中取出。栈的这种操作规则被称为:LIFO(Last InFirst Out,后进先出)

七、CPU提供的栈机制

1、8086CPU提供入栈和出栈指令,最基本的两个是PUSH(入栈)和POP(出栈)。

(1)push ax 表示将寄存器 ax 中的数据送入栈中

(2)pop ax 表示从栈顶取出数据送入 ax。

8086CPU的入栈和出栈操作都是以为单位进行的。

                段寄存器SS——存放栈顶的段地址

                寄存器SP——存放偏移地址

任意时刻,SS:SP指向栈顶元素。push 指令和 pop 指令执行时,CPU从SS和SP中得到栈顶的地址。


现在,我们可以完整地描述 push 和 pop 指令的功能了,例如 push ax,push ax 的执行,由以下两步完成。
(1)SP = SP - 2,SS:SP 指向当前栈顶前面的单元,以当前栈顶前面的单元为新的栈顶;
(2)将ax 中的内容送入SS:SP指向的内存单元处,SS:SP此时指向新栈顶。

 

从图中我们可以看出,8086CPU中,入栈时,栈顶从高地址向低地址方向增长

八、栈顶超界的问题

九、push、pop

十、栈段

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值