- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验4--jun
南昌大学实验报告
学生姓名: 学 号: 5 专业班级: 电三106
实验类型:□ 验证 □ 综合 √ 设计 □ 创新 实验日期: 实验成绩:
实验循环程序实验DEBUG程序、CODEVIEW调试程序的方法,并检查和验证结果的正确性。
二.实验内容
1. 已知字数组定义如下:ARRAY DW 12,78,55,4,125,96
MAX DW ?
编制程序求出该ARRAY数组中的最大数放入MAX单元。
data segment
array dw 12,78,55,4,125,96
max dw ?
data ends
code segment
assume cs:code,ds:data
start:
mov ax,data
mov ds,ax
mov si,0
mov ax,array[si] ;把第一个数给max
mov cx,5 ;然后逐个比较
again: ;遇上比max更大的,
add si,2 ;则把值给max。
dec cx
jcxz exit
cmp ax,array[si]
ja again
mov ax,array[si]
jmp again
exit:
mov max,ax
mov ah,4ch
int 21h
code ends
end start
max里存放的结果为 7D 00
2. 预留字符串口令,输入口令串与预留密码串比较。若匹配则显示“MATCH!CONGRATULATION”,否则显示“NOMATCH!”,并让用户重新输入,程序能对口令进行测试,但测试次数最多3次,若3次输入密码皆错,给出相应的提示信息,程序退出。
data segment
password db abcdef$
count EQU 6
input db 20,?,20 dup(?)
message1 db 0dh,0ah,Please input the password:$
message2 db 0dh,0ah,MATCH$
message3 db 0dh,0ah,NO MATCH!,PROGRAM TERMINATED!$
message4 db 0dh,0ah,Password input the wrong attain three,
db and the program will be over$
data ends ;相比实验三,增加了message4
code segment
assume cs:code,ds:data
start:
mov ax,data
mov ds,ax
mov di,3 ;多增加了一个di变量,使程序只能输错3次。
begin:
dec di
lea dx,message1 ;输出提示
mov ah,09
int 21h
lea dx,input ;输入字符串,保存在input里
mov ah,0ah
int 21h
mov si,0
mov al,input[si+1] ;比较密码的长度
cmp al,count
jnz output1
mov si,0
mov cx,count
again: ;取出input里面的字符
mov al,password[si] ;分别与password里的
mov bl,
文档评论(0)