实验1
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 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段中的数据为多少?
答: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。
实验二
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段中的数据为多少?
答:23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
(2)CPU执行程序,程序返回前,cs=076C,ss=076B,ds=076A。
(3)设程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。
(4) 对于如下定义的段:
name segment
......
name ends
如果段中的数据占N个字节则程序加载后,该段实际占有的空间为((N+15)/16)*16)
实验三
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段中的数据为多少?
答:23 01 56 04 00 00 00 00 00 00 00 00 00 00 00 00
(2)CPU执行程序,程序返回前,cs=076A、ss=076E、ds=076D。
(3)设程序加载后,code段的段地址为X,则data段的段地址为X+3,stack段的段地址为X+4。
实验4
如果将(1),(2),(3)题中的最后一条伪指令"end start"
改为"end"(也就是说,不指明程序的入口)
,则哪个程序仍然可以正确执行?请说明原因。
将修改前和修改后的反汇编代码进行比较:
实验(1)
实验(2)
实验(3)
只有实验三可以正确执行。原因在于不指明程序入口,程序默认从IP=0处执行;实验3是代码段在前,而实验1、2是代码段在后。所以实验3仍可以正确执行。
实验5
① 在实现数据相加前,逻辑段 c 的 8 个字节:00 00 00 00 00 00 00 00
② 执行完实现加运算的代码后,逻辑段 c 的 8 个字节:02 04 06 08 0A 0C 0E 10
实验6
b中的数据逆序存
总结:对内存的分配有了更深刻的了解。
原文:https://www.cnblogs.com/zakon/p/10017970.html