在8086模拟器中运行汇编求平均值程序.pdfVIP

在8086模拟器中运行汇编求平均值程序.pdf

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

在8086模拟器中运⾏汇编求平均值程序

DATA1SEGMENT

dataDW90,95,54,65,36,78,66,0,99,50,-1

AverageDW0

DATA1ENDS

CODE1SEGMENT

ASSUMECSCODE1,DSDATA1

STARTMOVAX,DATA1

MOVDS,AX

XORAX,AX

XORDX,DX;⽤(DX,AX)来保存数组元素之和

XORCX,CX;⽤CX来保存数组元素个数

LEASI,data;⽤指针SI来访整个数组

againMOVBX,wordptr[SI]

CMPBX,0

JLover

ADDAX,BX

ADCDX,0;把当前数组元素之值加到(DX,AX)中

INCCX;数组元素个数加1

ADDSI,2

JMPagain

overJCXZexit;防⽌零作除数,即数组是空数组

DIVCX

MOVAverage,AX

exitMOVAX,4C00H

INT21H

CODE1ENDS

ENDSTART

score的平均整数,并存⼊内存字变量Average中,数组以-1为结束标志。

xoreax,eax

是异或运算,两数相反为1;两数相同为0。由于这两个数相同,异或后等于清0;由于它⽐moveax,0效率⾼,所以⼀般⽤它。

LEA取有效地址指令(LoadEffectiveAddress)

取源操作数地址的偏移量,并把它传送到⽬的操作数所在的单元。

下⾯两条指令就是等价的,他们都取TABLE的偏移地址,然后送到BX中,即

LEABX,TABLE

MOVBX,OFFSETTABLE

带进位加法指令ADC(AdditionCarry)

格式

ADCOPRD1,OPRD2

功能

OPRD1--OPRD1+OPRD2+CF

说明

1.OPRD1为任⼀通⽤寄存器或存储器操作数,可以是任意⼀个通⽤寄存器,⽽且还可以是任意⼀个存储器操作数.

OPRD2为⽴即数,也可以是任意⼀个通⽤寄存器操作数.⽴即数只能⽤于源操作数.

2.OPRD1和OPRD2均为寄存器是允许的,⼀个为寄存器⽽另⼀个为存储器也是允许的,但不允许两个都是存储器操作数.

3.加法指令运算的结果对CF、SF、OF、PF、ZF、AF都会有影响.以上标志也称为结果标志.

4.该指令对标志位的影响同ADD指令.

div是除法指令,使⽤div做除法的时候应注意以下题:

1、除数:有8位和16位两种,在⼀个寄存器或者内存中。

2、被除数:默认放在AX或(DX和AX)中,如果除数为8位,被除数为16位,被除数默认在AX中存放,如果除数为16位,被除数为32

位,被除数则在(DX和AX)中存放,DX存放⾼16位,AX存放低16位。

3、结果:如果除数是8位,则AL存储除法操作的商,AH存储除法操作的余数;如果除数是16位,则AX存储除法操作的商,DX存储除法

操作的余数。

格式如下:

divreg

div内存单元

以100001/100为例,100001⼤于65535,所以只能⽤dx和ax两个寄存器联合存放100001,也就是说要进⾏16位的除法。除数100

⼩于255,可以在⼀个8位的寄存器中存放,但是被除数是32位的,除数应为16位,所以要使⽤⼀个16位的寄存器来存放除数100.

dx和ax分别存放100001的⾼16位和低16位值,所以将100001表⽰为16进制的形式:186a1h.

data1段的地址被编译为00710h,10个数据被放⼊此;但是为什么在模拟器中此地址出现在栈的模拟中;

0710被放⼊DS寄存器;SI⽬前是0;

第⼀个数被放⼊BX中;over标号编译后的地址为020h;

第⼀个数加完,AX为5A(10进制的90);

看BX是否为0;

加完⼀个数,CX为1;

SI指向下⼀个数;again编译后的地址为0E

文档评论(0)

孙二娘 + 关注
实名认证
文档贡献者

专注文档领域

1亿VIP精品文档

相关文档