| 
 | 
 
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册  
 
x
 
 本帖最后由 shuiyu 于 2017-7-16 00:51 编辑  
 
PS:还欠着2017.7.12与2017.7.13这两天的任务没完成  
 
越努力,越幸运。欢迎大家来看我的笔记  小白刚学,不对的请各位大佬指正,谢谢   
 
实验五 
 
(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  
 
①CPU执行程序,程序返回前,data段中的数据 不变 。  
②CPU执行程序,程序返回前,CS= 0B37H ,SS= 0B36H ,DS= 0B35H 。 
③设程序加载后,CODE段的段地址为X,则DATA段的段地址为 X-2 ,STACK段的段地址为 X-1 。 
 
解:这题把程序写出来,用debug执行完后即可得到答案。唯一难理解的就是出栈和入栈对数据处理的区别(记得“先入后出”  )。 
 
(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  
 
①CPU执行程序,程序返回前,data段中的数据 不变 。  
②CPU执行程序,程序返回前,CS= 0B37H ,SS= 0B36H ,DS= 0B35H 。 
③设程序加载后,CODE段的段地址为X,则DATA段的段地址为 X-2 ,STACK段的段地址为 X-1 。 
④对于如下定义的段: 
name segment 
…… 
name ends 
如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为 ((N+15)/16)*16 。 
 
④课本答案: 
N分为被16整除和不被16整除。  
当N被16整除时: 占有的空间为(N/16)*16  
当N不被16整除时: 占有的空间为(N/16+1)*16,N/16得出的是可以整除的部分,还有一个余数,余数肯定小于16,加上一个16。 
程序加载后分配空间是以16个字节为单位的,也就是说如果不足16个字节的也分配16个字节。  
两种情况总结成一个通用的公式:((N+15)/16)*16  
 
自己的理解:前三题和上一题相同的就不说了。结合答案可得:“dw”定义字型数据,如果不足16个字节的也分配16个字节。 以此类推“db”定义字节型数据,如果不足8个字节的也分配8个字节(这就大错特错了  ),经过我的验证,“db”定义字节型数据,如果不足8个字节的也分配16个字节 
 
 
(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  
 
①CPU执行程序,程序返回前,data段中的数据 不变 。  
 
②CPU执行程序,程序返回前,CS= 0B37H ,SS= 0B36H ,DS= 0B35H 。 
 
③设程序加载后,CODE段的段地址为X,则DATA段的段地址为 X+3 ,STACK段的段地址为 X+4 。 
 
解:一二小题和前面相同,就不多讲了。第三小题:因为DATA段和STACK段的位置发生了改变,故段地址发生了改变;充分说明编译器是从上往下读程序的。 
 
(4)如果将(1)、(2)、(3)题中的最后一条伪指令“end start”改为“end”(也就是说,不指明程序的入口),则哪个程序仍然可以正确执行?请说明原因。 
解:第三条程序仍然可以正确执行,如果不指明入口位置,则程序从所分配的空间开始执行,前2个是数据段,只有从第3条开始是指令代码。 
 
(5)程序如下,编写code段中代码,将a段和b段中的数据依次相加,将结果存到C段中。 
成功生成EXE执行文件: 
 
 
 
(6)程序如下,编写code段中代码,用PUSH指令将A段中的前8个字型数据,逆序存储到B段中。 
成功生成EXE执行文件: 
 
 
 
谢谢小甲鱼带来的视频教程,感谢!!    
 
 
    
本节结束,多谢览阅! 
越努力,越幸运。谢谢大家来看我的笔记  小白刚学,不对的请各位大佬指教,谢谢   |   
 
评分
- 
查看全部评分
 
 
 
 
 
 |