assume ds:data, cs:code, ss:stack data segment db 16 dup(0) ;预留16个字节单元,初始值均为0 data ends stack segment db 16 dup(0) ;预留16个字节单元,初始值均为0 stack ends code segment start: mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 16 ;设置栈顶 mov ah, 4ch int 21h code ends end start
对源程序进行编译、连接
debug使用d命令查看当前CS:IP指向的内存单元为076C:0000,接着使用u命令反汇编对应的内存,得到目标语句的地址为076C:000A
使用g命令执行到line17之后,line19之前
① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS) = 076B, 寄存器(CS) = 076C
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X-2, stack的段地址是 X-1
assume ds:data, cs:code, ss:stack data segment db 4 dup(0) data ends stack segment db 8 dup(0) stack ends code segment start: mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 8 mov ah, 4ch int 21h code ends end start
过程和任务1一致
可以看到目标命令地址为076C:000A
使用g命令执行到line17之后,line19之前
① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS) = 076B, 寄存器(CS) = 076C
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X-2, stack的段地址是 X-1
assume ds:data, cs:code, ss:stack data segment db 20 dup(0) data ends stack segment db 20 dup(0) stack ends code segment start: mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 20 mov ah, 4ch int 21h code ends end start
使用g命令执行到line17之后,line19之前
① 在debug中将执行到line17结束、line19之前,记录此时:寄存器(DS) = 076A, 寄存器(SS) = 076C, 寄存器(CS) = 076E
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X-4, stack的段地址是 X-2
assume ds:data, cs:code, ss:stack code segment start: mov ax, data mov ds, ax mov ax, stack mov ss, ax mov sp, 20 mov ah, 4ch int 21h code ends data segment db 20 dup(0) data ends stack segment db 20 dup(0) stack ends end start
① 在debug中将执行到line9结束、line11之前,记录此时:寄存器(DS) = 076C, 寄存器(SS) = 076E, 寄存器(CS) = 076A
② 假设程序加载后,code段的段地址是X,则,data段的段地址是X+2, stack的段地址是 X+4
① 对于如下定义的段,程序加载后,实际分配给该段的内存空间大小是 ([N/16]+1)*16
xxx segment db N dup(0) xxx ends
② 如果将程序task1_1.asm, task1_2.asm, task1_3.asm, task1_4.asm中,伪指令 end start 改成 end , 哪一个程序仍然可以正确执行。结合实践观察得到的结论,分析、说明原因。
答:只有task1_4.asm仍然可以正确执行。end start通知了编译器程序的入口在start处,去掉start,可能会导致定位错误。
以task1_1.asm为例:
此时CS:IP指向的实际为数据段,u命令反汇编发现CS:IP处的值为数据段预留的0,而程序将其当作指令执行了,明显出错
assume cs:code code segment mov ax, 0b800h mov ds, ax mov bx, 0f00h mov cx, 50h ;循环80次 mov ax, 0403h s: mov ds:[bx], ax add bx, 2 loop s mov ah, 4ch int 21h code ends end
对于源码进行编译、连接后运行
assume cs:code data1 segment db 50, 48, 50, 50, 0, 48, 49, 0, 48, 49 ; ten numbers data1 ends data2 segment db 0, 0, 0, 0, 47, 0, 0, 47, 0, 0 ; ten numbers data2 ends data3 segment db 16 dup(0) data3 ends code segment start: mov bx 0 mov ax data1 mov ds ax mov cx 0ah s: mov ax, [bx] add ax, [bx+10h] ;data1和data2的数据相加 mov [bx+20h], ax ;放到data3段中 inc bx loop s mov ah, 4ch int 21h code ends end start
可以发现完美相加并保存
assume cs:code data1 segment dw 2, 0, 4, 9, 2, 0, 1, 9 data1 ends data2 segment dw 8 dup(0) data2 ends code segment start: mov ax,data1 mov ds,ax mov ax,data2 mov ss,ax mov sp,16 mov bx,0 mov cx,8 s: mov ax,[bx] push ax add bx,2 loop s mov ah, 4ch int 21h code ends end start
assume cs:code, ds:data data segment db 'Nuist' db 2, 3, 4, 5, 6 data ends code segment start: mov ax, data mov ds, ax mov ax, 0b800H mov es, ax mov cx, 5 mov si, 0 mov di, 0f00h s: mov al, [si] and al, 0dfh mov es:[di], al mov al, [5+si] mov es:[di+1], al inc si add di, 2 loop s mov ah, 4ch int 21h code ends end start
答:作用是将小写字母变成大写字母
答:决定输出的字母的颜色
assume cs:code, ds:data data segment db 'Pink Floyd ' db 'JOAN Baez ' db 'NEIL Young ' db 'Joan Lennon ' data ends code segment start: mov ax,data mov ds,ax mov bx,0 mov cx,4 s: mov al,ds:[bx] or al,20h mov ds:[bx],al add bx,16 loop s mov ah, 4ch int 21h code ends end start
先运行到程序退出前
然后查看数据段data对应的内存空间
可以看到每一行的第一个大写字母被替换小写
assume cs:code, ds:data, es:table data segment db '1975', '1976', '1977', '1978', '1979' dd 16, 22, 382, 1356, 2390 dw 3, 7, 9, 13, 28 data ends table segment db 5 dup( 16 dup(' ') ) table ends code segment start: mov ax,data mov ds,ax mov ax,table mov es,ax mov bx,0 mov bp,0 mov cx,5 s: mov ax,ds:[bx] mov dx,ds:[bx+2] mov es:[bp],ax mov es:[bp+2],dx mov byte ptr es:[bp+4],' ' add bx,4 add bp,10h loop s mov bp,0 mov cx,5 s1: mov ax,ds:[bx] mov dx,ds:[bx+2] mov es:[bp+5],ax mov es:[bp+7],dx mov byte ptr es:[bp+9],' ' add bx,4 add bp,10h loop s1 mov bp,0 mov cx,5 s2: mov ax,ds:[bx] mov es:[bp+0ah],ax mov byte ptr es:[bp+0ch],' ' add bx,2 add bp,10h loop s2 mov bp,0 mov cx,5 s3: mov ax,es:[bp+5] mov dx,es:[bp+7] div word ptr es:[bp+0ah] mov es:[bp+0dh],ax mov byte ptr es:[bp+0fh],' ' add bp,10h loop s3 mov ah, 4ch int 21h code ends end start
可以看到成功写入