网站大量收购闲置独家精品文档,联系QQ:2885784924

《汇编语言》第二版第五章.ppt

  1. 1、本文档共104页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
5.7 一段安全的空间 不过为了谨慎起见,在进入DOS后,我们可以先用Debug 查看一下,如果0:200~0:2FF单元的内容都是0的话,则证明DOS 和其他合法的程序没有使用这里。 为什么DOS和其他合法的程序一般都不会使用0:200~0:2FF这段空间?我们将在以后的课程中讨论这个问题。 5.7 一段安全的空间 好了,我们总结一下: (1)我们需要直接向一段内存中写入内容; (2)这段内存空间不应存放系统或其他程序的数据或代码,否则写入操作很可能引发错误。 (3)DOS方式下,一般情况, 0:200~0:2FF 空间中没有系统或其他程序的数据或代码; (4)以后,我们需要直接向一段内存中写入内容时,就使用0:200~0:2FF这段空间。 5.8 段前缀的使用 我们考虑一个问题: 将内存ffff:0~ffff:b段元中的数据拷贝到 0:200~0:20b单元中。 分析一下 程序代码 改进的程序代码 5.8 段前缀的使用 分析一下: (1) 0:200~0:20b单元等同于0020:0~0020:b单元,它们描述的是同一段内存空间: (2)拷贝的过程应用循环实现,简要描述如下: 初始化:X=0 循环12次: 将ffff:X单元中的数据送入0020:X(需要用一个寄存器中转) X=X+1 5.8 段前缀的使用 分析一下: (续) (3)在循环中,源单元ffff:X和目标单元的0020:X的偏移地址X是变量。我们用bx来存放。 (4)我们用将0:200~0:20b用0020:0~0020:b描述,就是为了使目标单元的偏移地址和源始单元的偏移地址从同一数值0开始。 5.8 段前缀的使用 5.8 段前缀的使用 因源单元ffff:X和目标单元0020:X 相距大于64KB,在不同的64KB段里,程序中,每次循环要设置两次ds。 这样做是正确的,但是效率不高。 我们可以使用两个段寄存器分别存放源单元ffff:X和目标单元0020:X的段地址,这样就可以省略循环中需要重复做12次的设置ds的程序段。 5.8 段前缀的使用 5.8 段前缀的使用 改进的程序中,使用 es 存放目标空间0020:0~0020:b的段地址,用ds存放源空间ffff:0~ffff:b的段地址。 在访问内存单元的指令“mov es:[bx],al”中 ,显式地用段前缀 “es:” 给出单元的段地址,这样就不必在循环中重复设置ds。 小结 5.4 Debug和汇编编译器Masm对指令的不同处理 Debug中的情况: 5.4 Debug和汇编编译器Masm对指令的不同处理 将汇编源程序存储为compare.asm用masm、link生成compare.exe,用debug加载compare.exe,如图: 5.4 Debug和汇编编译器Masm对指令的不同处理 比如我们可以这样访问2000:0单元: mov ax,2000h mov ds,ax mov al,ds:[0] 5.5 loop和[bx]的联合应用 考虑这样一个问题: 计算ffff:0~ffff:b单元中的数据的和,结果存储在dx中。 我们还是先分析一下 5.5 loop和[bx]的联合应用 计算ffff:0~ffff:b单元中的数据的和,结果存储在dx中。 分析: (1)运算后的结果是否会超出 dx 所能存储的范围?  ffff:0~ffff:b内存单元中的数据是字节型数据,范围在0~255之间,12个这样的数据相加,结果不会大于 65535 ,可以在dx中存放下。 5.5 loop和[bx]的联合应用 计算ffff:0~ffff:b单元中的数据的和,结果存储在dx中。 分析: (2)我们是否将 ffff:0~ffff:b中的数据直接累加到dx中?  当然不行,因为ffff:0~ffff:b中的数据是8位的,不能直接加到16位寄存器dx中。 5.5 loop和[bx]的联合应用 计算ffff:0~ffff:b单元中的数据的和,结果存储在dx中。 分析: (3)我们能否将ffff:0~ffff:b中的数据累加到dl中,并设置(dh=0,从而实现累加到dx中的目标?  这也不行,因为dl是8位寄存器,能容纳的数据的范围在小 255 之间,ffff : 0~ffff:b中的数据也都是 8 位,如果仅向dl中累加12个 8 位数据,很有可能造成进位丢失。 5.5 loop和[bx]的联合应用 计算ffff:0~ffff:b单元中的数据的和,结果存储在dx中。 分析: (4)我们到底怎样将用ffff:0~ffff:b中的8

您可能关注的文档

文档评论(0)

wuyoujun92 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档