实验5:编写、调试具有多个段的程序


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

assume cs:code,cs:data,ss:stack

data segment
	dw 0123h,0456h,0789h,0abch,0defh,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 = 076CH,ss = 076BH,ds = 076AH
设程序加载后,code段的段地址为X,则data段的段地址为?X-2 ,stack段的段地址为?X-1


二、将下面的程序编译、连接、用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段中的数据为多少?

在这里插入图片描述
在这里插入图片描述
数据段的起始偏移地址为0,所以我们查看ds:0处,可以看到第一行就是data中的数据


三、将下面的程序编译、连接、用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	

在这里插入图片描述
可以看出来 还是和之前一样,没有太大意义上的区别。

我们这里data和stack定义的都是小于16个字节的,系统默认分配是分配16个字节,其余补00

以上代码如果将end替换end start都可以运行,但是只有第三个例子中才能正确运行,因为如果不指明入口,程序会从加载进内存的第一个单元起开始执行,前两题中,定义的是数据,但CPU还是将数据当作指令代码执行了,是逻辑上发生了问题,但是是可以执行的。


四、编写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:
	mov ax,a
	mov ds,ax
	
	mov ax,b
	mov es,ax
	
	mov bx,0
	mov cx,8
s:	
	mov dl,[bx] ;将ds:bx中的内容送入dl(这里是字节单元内容)
	add dl,es:[bx] ;将es:bx内容与ds:bx内容相加,结果存在dl中
	
	push ds ;保护ds
	mov ax,c
	mov ds,ax
	mov [bx],dl ; 送入c段
	pop ds
	inc bx
	loop s
	
	

code ends
end start	

五、编写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	

code ends
end start	
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:
	mov ax,a
	mov ds,ax ;ds指向a段
	
	mov ax,b
	mov ss,ax ;ss指向b段
	mov sp,16 ;初始化栈顶,ss:sp指向栈顶,意味着b是一个栈结构
	
	mov bx,0
	mov cx,8
	
s:	push ds:[bx] ;将a段中的字单元直接压栈,这样子就是逆序的
	add bx,2
	loop s
	
	
	
	
code ends	

code ends
end start	
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值