1、将下面的程序编译连接,用debug加载,跟踪然后回答问题
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
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,16
mov ax,data
mov ds,ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
end start
(1)CPU执行程序,程序返回前,data段中的数据不变 。
(2)CPU执行程序,程序返回前,CS=076C,SS=076B,DS=076A 。
(3)设程序加载后,code段的段地址为X,则data段的段地址为 X-2 ,stack段的段地址为 X-1 。
实验结果与分析:
因为该题目要求在程序返回前,所以用g命令直接定位到076C:001D的位置,即为mov ax,4c00h处。
2、将下面的程序编译连接,用Debug加载,跟踪,然后回答问题
assume cs:code,ds:data,ss:stack
data segment
dw 0123h,0456h
data ends
stack segment
dw 0,0
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,16
mov ax,data
mov ds,ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
end start
(1)CPU执行程序,程序返回前,data段中的数据不变,同一行内剩余的空间补0 。
(2)CPU执行程序,程序返回前,CS= 076CH ,SS= 076BH ,DS= 076AH 。
(3)设程序加载后,code段的段地址为X,则data段的段地址为 X-2 ,stack段的段地址为 X-1 。
(4)对于如下定义的段:
name segment
……
name ends
如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为 (N/16+1)*16个字节 。
实验结果与分析:
因为该题目要求在程序返回前,所以用g命令直接定位到076C:001D的位置,即为mov ax,4c00h处。
虽然数据段中的的数据只占用了4个字节,但实际上却占用了16个字节的空间,空闲下来的空间通过图(1)与图(2)的比较,我们可以观察到全部补了0,所以实际占有的空间必为16的倍数。而且我认为若该题将data段中的数据改为0123h, 0456h,0123h, 0456h,0123h, 0456h,0123h, 0456h,0123h,则实验结果会更明显一些。
3、将下面的程序,用Debug加载,跟踪,然后回答问题
assume cs:code, ds:data, ss:stack
code segment
start: mov ax,stack
mov ss, ax
mov sp,16
mov ax, data
mov ds, ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
data segment
dw 0123h, 0456h
data ends
stack segment
dw 0,0
stack ends
end start
(1)CPU执行程序,程序返回前,data段中的数据 不变,同一行内剩余的空间补0 。
(2)CPU执行程序,程序返回前,CS= 076AH ,SS= 076EH ,DS= 076DH 。
(3)设程序加载后,CODE段的段地址为X,则DATA段的段地址为 X+3 ,STACK段的段地址为 X+4 。
实验结果与分析:
4、如果将(1)(2)(3)题中最后一条指令“end start ”改成“ end ”(不指明程序的入口),则哪个程序可以正确执行?请说明理由
我认为第三条程序仍然可以正确执行,如果不指明入口位置,则程序从所分配的空间开始执行,前2个前面是数据段,只有从第3条开始是指令代码。
5、程序如下,编写code 段中的代码,将a段和b段中的数据依次相加,将结果存入c段中
assume cs:code
a segment
db 1,2,3,4,5,6,7,8
a ends
b segment
db 1,2,3,4,5,6,7,8
b ends
c segment
db 8 dup(0)
c ends
code segment
start:
mov ax,a
mov ds,ax
mov ax,b
mov es,ax
mov bx,0
mov cx,8
s: mov al,ds:[bx]
add es:[bx],al
inc bx
loop s
mov ax,c
mov ds,ax
mov bx,0
mov cx,8
s0: mov al,es:[bx]
mov ds:[bx],al
inc bx
loop s0
mov ax,4c00h
int 21h
code ends
end start
实验结果与分析:
① 在实现数据相加前,逻辑段 c 的 8 个字节
② 执行完实现加运算的代码后,逻辑段 c 的 8 个字节
将相加后的结果存在ds段寄存器中,结果正确。
6、程序如下,编写code中的代码,用push指令将a段中的前8个字形数据,逆序存储到b段中
assume cs:code
a segment
dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0dh,0eh,0fh,0ffh
a ends
b segment
dw 8 dup(0)
b ends
code segment
start:
mov ax,a
mov ds,ax
mov ax,b
mov bx,0
mov ss,ax
mov sp,16
mov cx,8
s: push ds:[bx]
add bx,2
loop s
mov ax,4c00h
int 21h
code ends
end start
实验结果与分析:
① 在 push 操作执行前,查看逻辑段 b 的 8 个字单元信息截图
② 执行 push 操作,然后再次查看逻辑段 b 的 8 个子单元信息截图
总结:
通过本次实验我发现了自己在细节处理中的不足,但是同时也复习了之前的知识点,写多行代码的能力有待提高。