王爽《汇编语言》第6章 包含多个段的程序 学习笔记

目录

问题1:编程计算8个数据的和,结果存在ax寄存器中

问题2:利用栈,将程序中的数据逆序存放

问题3:将数据、代码放入不同的段


问题1:编程计算8个数据的和,结果存在ax寄存器中

0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h

思考:一个个加很麻烦,想用循环的方法来叠加,所以要将这八个数据存储在一组地址连续的内存单元中。而可以用的空间可以由系统来分配,所以将数据写在程序里。

最终代码:

assume cs:code

code segment

    dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h

   start:       mov bx,0
                mov ax,0
              s:add ax,cs:[bx]
                add bx,2
                loop s

                mov ax,4c00h
                int 21h

code ends

end start

其中

dw即define word,含义是定义字形数据(也可以认为是开辟空间,然后放入数据)。当程序被加载入内存时,这些数据也被加载入内存,由于数据在程序最前面,故cs为这些数据的段地址,0,2,4,6,8,A,C,E为偏移地址。

end start 指明程序的入口,在编译、连接后,被转化为一个入口地址,存储在可执行文件的描述性信息中。当程序被加载入内存之后,加载者可以从文件的描述信息中读到程序的入口地址,设置CS:IP。这样CPU就可以从start处开始执行。

问题2:利用栈,将程序中的数据逆序存放

assume cs:codesg

codesg segment

    dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
    dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

   start:       mov ax,cs
                mov ss,ax
                mov sp,30h //将cs:10-cs:2F的内存空间当作栈来使用。所以设置ss:sp指向cs:30
            
                mov bx,0
                mov cx,8
                s:push cs:[bx]
                add bx,2
                loop s   //数据依次入栈

                mov bx,0
                mov cx,8
                s0:pop cs:[bx]
                add bx,2
                loop s0  //数据依次出栈

                mov ax,4c00h
                int 21h  //程序返回

codesg ends

end start

问题3:将数据、代码放入不同的段

放在一个段的问题:

(1)显得混乱

(2)如果数据、代码和栈需要的空间超过64KB,就不能放在一个段。(8086CPU的一个段的容量不能大于64KB)

assume cs:code,ds:data,ss:stack

data segment

    dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h

data ends

stack segment

    dw 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0

stack ends

code segment

    start:  mov ax,stack
            mov ss,ax
            mov sp,20h

            mov ax,data
            mov ds,ax

            mov bx,0
            
            mov cx,8
        s:  push [bx]
            add bx,2
            loop s

            mov bx,0

            mov cx,8
       s0:  pop [bx]
            add bx,2
            loop s0

            mov ax,4c00h
            int 21h

code ends

end start

注:CPU到底如何处理我们定义的段中的内容,是当作指令执行,当作数据访问,还是当作栈空间,完全是靠程序中具体的汇编指令,和汇编指令对CS:IP,SS:SP,DS等寄存器的设置来决定的,而不是靠段的名称或者类似assume cs:code的语句。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云霄星乖乖的果冻

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值