实验五

试验任务:

实验1

将下面的程序编译链接, 用Debug加载、跟踪,然后回答问题

实验五_第1张图片

运行截图如下

实验五_第2张图片

(1)CPU执行程序,程序返回前,data段中的数据为多少?

       23 01 56 04 89 07 BC 0A EF 0D ED 0F BA 0C 87 09

(2)CPU执行程序,程序返回前,cs=076C,ss=076B,ds=076A。

(3)设程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。

 

实验2

将下面的程序编译、连接,用Debug加载、跟踪,然后回答问题。

实验五_第3张图片

实验五_第4张图片

 

 

CPU执行程序,程序返回前,data段的数据为多少?

 23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00

CPU执行程序,程序返回前,cs=076C、ss=076B、ds=076A。

③设程序加载后,code段的段地址为X,则data段的段地址为  X-2    、stack段的段地址为  X-1    。

④对于如下定义的段:

name  segment

.........

name ends

如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为  (N/16+1)*16    。

 

实验3

将下面的程序编译、连接,用Debug加载、跟踪,然后回答问题。

实验五_第5张图片

实验五_第6张图片

 

 

CPU执行程序,程序返回前,data段的数据为多少?

23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00

CPU执行程序,程序返回前,cs=076A、ss= 076E、ds=076D  。

③设程序加载后,code段的段地址为X,则data段的段地址为 X+3  、stack段的段地址为  X+4  。

 

实验4

如果将(1)、(2)、(3)题中的最后一条伪指令“end start”改为“end”(也就是说,不知名程序的入口),则哪个程序仍然可以正确执行?请说明原因

答:(3)可以,因为(1)、(2)的开始都是数据段,而(3)的开始是指令。

 

实验5

1.实验代码

复制代码
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 0,0,0,0,0,0,0,0
c ends        ; 
code segment
start: mov ax,a
         mov ds,ax
         mov ax,c
         mov es,ax
         mov bx,0
         mov cx,8
s1:    mov al,ds:[bx]
         mov es:[bx],al
         inc bx
         loop s1
         mov ax,b
         mov ds,ax
         mov bx,0
         mov cx,8
s2:     mov al,ds:[bx]
          add es:[bx],al
          inc bx
          loop s2

          mov ax,4c00h
          int 21h

code ends

end start
复制代码

2.在 debug 中调试程序

实验五_第7张图片

① 在实现数据相加前,逻辑段 c 的 8 个字节:00 00 00 00 00 00 00 00

② 执行完实现加运算的代码后,逻辑段 c 的 8 个字节:02 04 06 08 0A 0C 0E 10

3.根据①和②的调试,实验程序正确实现数据相加。

 

实验6

程序如下,编写code段中的代码,用push指令将a段中的前8个字型数据,逆序存储到b段中

源代码:

实验五_第8张图片

下面是调试过程:

实验五_第9张图片

这里是在push操作执行前,查看逻辑段b的8个子单元

实验五_第10张图片

你可能感兴趣的:(实验五)