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

四.实验结论

1

(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-2h,stack段的段地址为x-1h

因为data一共占16个字节,stack一共占16个字节。

2

(1)cpu执行程序,程序返回前,data段中的数据为:23 01 56 04

如下图所示:

(2)cpu执行程序,程序返回前,cs=076c,ss=076b,ds=076a

如下图所示:

(3)设程序加载后,code段的段地址为x,则data段的段地址为x-2h,stack段的段地址为x-1h

(4)对于如下定义的段:

name segment
...

name ends

如果段中的数据占n个字节,则程序加载后,该段实际占有的空间为:((n+15)/16)*16。

??因为每个段都是以16字节来对齐的,但是最大不能超过64KB 。这也就是说,如果你的段数据在16字节内,一样会被当做一个字节段来算,就是16字节。 要是大于16字节,多出来的1个字节也得有一个字节段的容量来存储它,所以这时得占两个字节段,就是32字节。 分为两种情况,如果n为16的倍数,则占空间为(n/16)*16。如果n不为16的倍数,则占空间为(n/16+1)*16。综上可以写成((n+15)/16)*16。

3.

(1)cpu执行程序,程序返回前,data段中的数据为:23 01 56 04

(2)cpu执行程序,程序返回前,cs=076a,ss=076e,ds=076d

(3)设程序加载后,code段的段地址为x,则data段的段地址为x+3h,stack段的段地址为x+4h

通过反汇编可看出。

4.

如果将(1)(2)(3)题中的最后一条伪指令“end start”改为“end”,则哪个程序仍可以正确执行?请说明原因。

只有第三个可以正常运行。因为前两个找不到程序入口无法执行第一条语句。(1)(2)开始是数据段,只有(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 0,0,0,0,0,0,0,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 dx,[bx]
  mov ax,b
  mov ds,ax
  add dx,[bx]
  mov ax,c
  mov ds,ax
  mov [bx],dx
  inc bx
  loop s
  mov ax,4c00h
  int 21h

code ends

end start

单步调试到mov [bx],dx之前,用d命令查看c中数据:

再用g命令调到程序返回前,用d命令查看c中数据

经验证,数据实现了相加。

6.

源代码如下:

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

code ends

end start

用t命令调试到push操作之前,用d命令查看b中内容

用g命令调试到程序返回前,再用d命令查看b中内容

经验证,数据实现了逆置。

五.总结与体会

通过学习编写多个段的程序,使我们编写的程序更加地清晰,更有条理。知道了段中的数据占n个字节,则程序加载后,该段实际占有的空间为((n+15)/16)*16。

在自己操作实践的过程中有些步骤不太熟练,以后仍要多操作,多练习。

原文地址:https://www.cnblogs.com/makaya/p/10013677.html

时间: 2024-10-02 12:54:07

实验五 编写、调试具有多个段的程序的相关文章

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

实验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]

汇编实验五 编写、调试具有多个段的程序

南京信息工程大学实验报告 实验名称   实验 5 编写.调试具有多个段的程序 实验日期  12.2 得分 学院   计软院 专业   计科 年级   2017级 班次    6班 姓名    江轲禹 学号    20171308227 一.实验目的 1. 理解和掌握将数据.代码.栈放入不同段的程序的编写和调试 2. 理解具有多个段的汇编源程序对应的目标程序执行时,内存分配方式 二.实验准备 1. 结合第6章教材和课件,复习第6章内容 2. 复习第3章「栈」的知识 三.实验内容 教材133实验 5

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

实验结论 实验1 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

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

实验任务一 将下面的程序编译.链接,用debug加载.跟踪,然后回答问题. 1 assume cs:code, ds:data, ss:stack 2 data segment 3 dw 0123h, 0456h, 0789h, 0abch, 0defh, 0fedh, 0cbah, 0987h 4 data ends 5 6 stack segment 7 dw 0, 0, 0, 0, 0, 0, 0, 0 8 stack ends 9 10 code segment 11 start: mo

【实验五】编写、调试具有多个段的程序

四.实验结论 *任务(1)(2)(3)基本步骤相同,这里只列举出(1)的实验步骤 步骤一:把要使用的代码粘贴到masm文件夹中. 步骤二:编译.连接.用debug调试. 步骤三:用r命令查看哥寄存器的值. cs是code的段地址,ds是data的段地址,ss是stack的段地址.这是因为代码前面的声明:   assume cs:code, ds:data, ss:stack 步骤四:用u命令反汇编,注意反汇编是code段,所以u命令后接的应该是cs. 步骤五:用g命令执行,根据反汇编得到的代码,

实验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 m

汇编试验五:编写、调试具有多个段的程序

ds 数据段放入数据正确: 两次push 操作后,ss栈段正确: 由于pop 操作顺序,ds数据段并没有发生改变: Source Code: 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,

汇编语言实验五

实验任务一 1.利用debug加载.跟踪程序 (1)先利用r命令来查看各个寄存器的值 (2)从cx中可知道程序的长度,用cx中的值减去20h(数据段和栈段已分配的空间)得到代码段的长度,用u命令精确反汇编 (3)先执行到000D之前,看看ds是否已成功指向数据段 (4)从上图可以看到ds已指向数据段,然后我们接着执行到程序返回前,即到001D之前,再查看一次数据段的内容 (5)从上图可以看到,数据段没有发生变化 2.书上的问题解答: (1)程序返回前,data段中的数据为 23 01 56 04

包含多个段的程序

在前一章我们提到0:200~0:2FF地址空间是相对安全的,但是这段空间的容量只有256个字节. 在操作系统中只要是通过操作系统申请的空间就都是安全的,操作系统负责给程序分配安全的空间.在操作系统允许的情况下,程序可以取得任意数量的空间. 按程序获取所需空间的时间,获取空间方法可分为两种: 在加载程序的时候为程序分配 在程序执行的过程中向系统申请 本书中不论描述第二种 对于汇编程序,如果需要他在被加载的时候取得所需的空间,就必须要在源程序中做出说明,对于汇编源程序来讲就是在汇编源程序中做出相应段