汇编语言 第六章 包含多个段的程序

1.安全空间:0:200~0:2FF

2.程序获取空间的两种方法:①通过一个加载程序(如debug等程序),将所要执行的程序加载到内存②通过向操作系统申请分配

6.1 在代码段中使用数据

问题思考:我们要将特定的数据进行累加,但是之前所学的程序都是通过push、pop等方法向内存中传入数据,有没有更加方便的操作呢?

有,这里我们在汇编程序中引入了dw(亲测不能改),定义字型数据(一个数据即使16位),如dw 0123h,0456h 意思就是说将0123h和0456h存到cs:0和cs:02处,也就是说,程序的段地址是cs,偏移地址从0到程序的地址之前都是存放这些数据的区域,以下面程序6.1为例:

assume cs:code 

code segment

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

    mov bx,0
    mov ax,0
    
    mov cx,8
s:  add ax,cs:[bx]
    add bx,2
    loop s
    
    mov ax,4c00h
    int 21h

code ends

end

这个程序是要将8个数据进行累加放到ax寄存器中,dw 后面定义了8个字型数据(0123h的地址是cs:0,0456h的地址是cs:2等等),存放到了cs:0处,程序是从cs:10开始执行的,下面的程序大家应该就能看懂啦!

这里补充一下命令:-t执行程序 -p到loop 标号处按(知道循环结束) -p在int 21h处按返回程序 -g 加地址 直接执行到该地址处

程序6.2对6.1做了改进,加入了start

assume cs:code 

code segment

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

start:    
    mov bx,0
    mov ax,0
    
    mov cx,8
s:        
    add ax,cs:[bx]
    add bx,2
    loop s
    
    mov ax,4c00h
    int 21h

code ends

end start

end start通知编译器程序的入口,在6.1程序中我们可以到处我们的程序是从dw 字型数据开始执行的,所以这里的start就是让cs:ip指向程序,而不是dw写入的数据域,自己可以上机练习,你会看到6.1与6.2之间ip改变了

6.2 在代码段中使用栈

程序6.3利用栈将定义的数据逆序排序

书中的程序我有个疑惑,要逆序排序8个字型数据,但是它为什么要dw 16个字型数据呢,这不是浪费空间么(学长说后面的中断会讲到)

assume cs:codesg

codesg segment 

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值