汇编语言(王爽版)实验5 编写、调试具有多个段的程序

(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段中的数据为多少?
答:data段中的数据未发生改变,还是0123h,0456h...
(2)CPU执行程序后,程序返回前,cs=_076E_,ss=_076D_,ds=_076C_
(3)设程序加载后,code段的段地址为X,则data段的段地址为_X-2_,stack段的段地址为_X-1_

(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段中的数据为多少?
答:data段中的数据未发生改变,还是0123h,0456h
(2)CPU执行程序后,程序返回前,cs=_076E_,ss=_076D_,ds=_076C_
(3)设程序加载后,code段的段地址为X,则data段的段地址为_X-2_,stack段的段地址为_X-1_
(4)对于如下定义的段:
name segment
...
name ends
如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为__(N/16+1)*16___。
【注:栈分配段空间只能是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

实验截图:
在这里插入图片描述
在这里插入图片描述

问题:
(1)CPU执行程序,程序返回前,data段中的数据为多少?
答:data段中的数据未发生改变,还是0123h,0456h
(2)CPU执行程序后,程序返回前,cs=_076C_,ss=_0770_,ds=_076F_
(3)设程序加载后,code段的段地址为X,则data段的段地址为_X+3_,stack段的段地址为_X+4_
(4)如果将(1)、(2)、(3)题中的最后一条指令
"end start"改为"end"(也就是说,不指名程序的入口),
则哪个程序仍然可以正确执行?说明原因。
答:第(3)个可以正确执行,CPU找不到程序的入口,
则从上往下顺序执行,第三个程序的第一个段刚好是代码段,不会影响。
我三个程序都执行了一下,刚开始发现结果都是没变,以为程序可以执行。
然后编译成exe文件并用ida调试发现没有end start的程序乱七八糟的,可能根本就找不到代码段执行,所以最后结果没有变。
(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 0,0,0,0,0,0,0,0
c ends

code segment
start:
	?
code ends
end start

答案:
	mov ax,c
	mov es,ax
	mov ax,a
	mov ds,ax
	mov cx,8
	mov bx,0
s0: #先把a的数据循环放c中
	mov dx,ds:[bx]
	mov es:[bx],dx
	inc bx
loop s0
	mov ax,b
	mov ds,ax
	mov bx,0
	mov cx,8
	mov dx,0
s1: #在把c中数据和b中数据相加
	add dx,ds:[bx]
	mov es:[bx],dx
	inc bx
loop s1
	mov ax,4c00h
	int 21h

程序如下,编写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 0,0,0,0,0,0,0,0
b ends
code segment
start:
	?
code ends
end start
答案:
mov ax,b
mov ss,ax
mov sp,10h #把指针指向b段,sp=10h,刚好可以push 8次,即push前8个字
mov ax,a
mov ds,ax #a段为data段
mov bx,0
mov cx,8
s0:push [bx] #把a段内容push到b段
add bx,2
loop s0
mov ax,4c00h
int 21h
code ends
end start
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会尽力回答您的问题。 在汇编语言中,程序可以被分为多个段,每个段都有自己的代码、数据和堆栈。编写调试具有多个段的程序需要注意以下几点: 1. 定义段 在汇编语言中,通过使用ASSUME语句来指定段寄存器和逻辑段之间的对应关系。例如,下面的代码段定义了两个逻辑段:CODE和DATA。 ``` ASSUME CS:CODE, DS:DATA CODE SEGMENT ; 代码段 CODE ENDS DATA SEGMENT ; 数据段 DATA ENDS ``` 2. 定义变量和常量 在数据段中,可以定义变量和常量。例如,下面的代码定义了一个字节型变量和一个字型常量。 ``` DATA SEGMENT MYBYTE BYTE ? MYWORD WORD 1234H DATA ENDS ``` 3. 定义堆栈 在汇编语言中,堆栈是由程序自己管理的。可以使用SS和SP寄存器来访问堆栈。在程序中必须定义堆栈的大小,以便程序运行时可以正确地使用堆栈。例如,下面的代码定义了一个堆栈段和堆栈大小。 ``` STACK SEGMENT STACK DW 100H DUP(?) STACK ENDS ``` 4. 编写代码 在代码段中,编写实际的程序代码。例如,下面的代码使用MOV指令将一个常量加载到AX寄存器中,并使用INT指令调用中断。 ``` CODE SEGMENT MOV AX, MYWORD INT 21H CODE ENDS ``` 5. 调试程序调试程序时,可以使用调试器来跟踪程序的执行过程。可以使用INT 3指令在程序中插入一个断点,当程序执行到这个断点时,程序会停止执行。例如,下面的代码在程序中插入了一个断点。 ``` CODE SEGMENT MOV AX, MYWORD INT 3 INT 21H CODE ENDS ``` 以上是编写调试具有多个段的程序所需要注意的几点。在实践中,需要根据具体的程序需求进行相应的调整和修改。总之,多练习、多尝试,才能更好地掌握汇编语言的编程技巧。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值