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,