(1)


①data段的数据在执行程序时,程序返回前并未改变

②程序返回前,CS=076C,SS=076B,DS=076A。

③由图中ss,ds,cs可知,若code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。

(2)


①由图可知,与(1)的结果一样,data段的数据在执行程序后,程序返回前仍未改变

②从图可知出,CPU执行程序,程序返回前,CS=076C,SS=076B,DS=076A。

③code段的段地址为X时,则data段的段地址为X-2,stack段的段地址为X-1。

④对比(1)(2)可以发现,(1)中data段数据有16个字节,占用了16个字节空间,而(2)中data段数据只有4个字节,但实际上(2)也占用了16字节的空间,其中不足的部分都用0补全了。所以推测,若段中数据为N个字节,则该段实际占用的空间为 ((N+15)/16)*16 个字节。

(3)


①data段的数据在执行程序后,程序返回前并未改变

②从图中可以看出,CPU执行程序,程序返回前,CS=076A,SS=076E,DS=076D。

③进一步可以发现,若code段的段地址为X,则data段的段地址为X+3,stack段的段地址为X+4。

(4)如果将最后一条伪指令“end start”改为“end”,相当于没有指明程序入口,此时程序就会从加载进内存的第一个单元起开始执行。在(1)(2)题中,都是数据先加载进内存,CPU会误把数据也当成指令执行,最终不能保证被正确执行;而(3)题则是代码段先被加载进内存,因而可以被正确执行。

(5)

源码

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 bx,0
  mov dx,0
  mov cx,8
s:mov dx,0
  mov ax,a
  mov ds,ax
  add dl,[bx]
  mov ax,b
  mov ds,ax
  add dl,[bx]
  mov ax,c
  mov ds,ax
  mov [bx],dl
  inc bx
  loop s
  mov ax,4c00h
  int 21h

code ends
end start

使用t命令单步调试至mov [bx],dl命令 ,此时上一条命令mov ds,ax已经执行完毕,此时ds中保存的就是c段的段地址

查看此时未加载完毕前c段中内容

运行到程序返回前,此时的DS中保留的就是c段的段地址,查看c段中的数据;

(6)

源码

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 ss,ax
  mov sp,0fh
  mov bx,0
  mov cx,8
s:push [bx]
  inc bx
  inc bx 
  loop s
  mov ax,4c00h
  int 21h

code ends
end start

将栈顶初始化

执行push操作前,b段中位置;

程序返回前,查看b段中数据(ss保存的数据);

数据逆置;



来自为知笔记(Wiz)


posted on 2018-11-30 22:00  sakura0—-0  阅读(91)  评论(1编辑  收藏  举报