ImageVerifierCode 换一换
格式:DOCX , 页数:35 ,大小:145.87KB ,
资源ID:6826383      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6826383.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(汇编语言程序设计报告.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

汇编语言程序设计报告.docx

1、汇编语言程序设计报告综合实验报告( 2014 - 2015 年度第 一 学期)名 称: 汇编语言程序设计综合实验 题 目: 汇编语言程序设计 院 系: 控制与计算机工程学院 班 级: 计科1203 学 号: 201209010324 学生姓名: 张毅民 指导教师: 王保义 王蓝婧 设计周数: 一周 成 绩: 日期: 2015 年 1 月实验一 用表格形式显示字符一、 实验要求按15*16列的表格形式显示ASC码为10H100H的所有字符,即以行为主的顺序及ASC码递增的次序依次显示对应的字符。每16个字符为一行,每行中的相邻两个字符之间用空白符隔开。二、 设计思路1. 设两个计数值,行和列,分

2、别为15、16,输出一个字符,输出一个空格,字符加1,判断是否输完一行,未输出完继续输出字符。每行输完后,输出回车换行符,判断是否输玩15行,未输出完,从新输出新的一行。2. 流程图三、设计要点、细节(1) 显示每个字符可使用功能号为02的显示输出功能调用: Mov ah,02h Mov dl,输出字符的ASC码 Int 21h 将dl初始化为10H,然后使用其加1以取得下一个字符的ASC码。(2) 显示空白符是,用其ASC码置0入dl寄存器。每行结束时,用回车和换行来结束本行并开始下一行。(3) 由于逐个显示相继的ASC码字符是,需要不断修改dl寄存器的内容,而显示空白、回车、换行也需要使用

3、dl寄存器,为此可使用堆栈保存dx。(即push pop指令)四、 实验程序及调试结果CODES SEGMENT;* ASSUME CS:CODESSTART: Mov bx,15 mov dl,10hloop: mov cx,16next: mov ah,02h int 21hinc dl;-输出空格 push dx mov dl,0 int 21hpop dx loop next ;未输完一行继续输出;-每行输完,输出换行回车 push dx mov dl,0dh int 21h mov dl,0ah int 21h pop dx dec bxjne loop;未输完15行从新输入下一行e

4、xit: ret CODES ENDSEND START五、实验结果六、实验心得本次实验是我初次实际上机编写汇编实验,实验很简单,但在编写中出现大大下小不少问题,在修改程序的过程中也渐渐熟悉了MASM软件,并且也简单了解了调试功能。本次实验我具体地了解到了如何输出单个字符(及2号功能调用DOS),也熟悉了用堆栈保存信息,并简单了解了循环程序设计。实验二 查找匹配字符串一、 实验要求程序接受用户键入的一个关键字以及一个句子,如果句子中不包含关键字则显示“No match!”;如果句子中包含关键字则显示“match!”,且把该字在句子中的位置用十六进制数显示出来。要求程序的执行过程如下:Enter

5、 keyword:abcEnter sentence:we are studying abcMatch at location:11H of the sentenceEnter sentence:xyzNo match!Enter sentence:二、 设计思路1. 输入关键字和一个句子,分别存入相应的缓冲区中(用功能调用2ah)。在句子中查找关键字用串比较命令cmpsb并加前缀repnz,SI为寄存器为关键字的指针, DI为寄存器为句子中正相比较的字段的指针,CX为寄存器存放关键字的字母个数(长度), 整个句子和关键字的比较过程可以用一个循环结构来完成,循环次数为:(句子长度-关键字长度)

6、+1; 在计算循环次数时,如遇到句子长度小于关键字长度的情况则应转向显示“no match”,循环中还需要用到BX寄存器,它用来保存句子中当前正在比较字段的首地址。比较完成有两种情况一种为句子比较完成,一种为在句子中找到与关键字相同的段,两种区别就是cx是否为零,为零则match。最后再用二进制转换十六进制将bx的数显示出来,即为关键字在句子中的位置。2.流程图 三、设计细节、要点(1)输入关键字和一个句子,分别存入相应的缓冲区中。可用功能调用0AH。(2)在句子中查找关键字: 关键字和句子中相应字段的比较可使用串比较指令。为此必须定义附加段,但附加段和数据段可以定义为同一段,以便于串指令的使

7、用,相应的寄存器内容也有了确定的含义,即如下: SI 寄存器为关键字的指针 DI 寄存器为句子中正相比较的字段的指针 CX 寄存器存放关键字的字母个数(长度) 整个句子和关键字的比较过程可以用一个循环结构来完成,循环次数为: (句子长度-关键字长度)+1在计算循环次数时,如遇到句子长度小于关键字长度的情况则应转向显示“no match”,循环中还需要用到BX寄存器,它用来保存句子中当前正在比较字段的首地址。 输出信息:用功能调用09h分“找到”或“找不到”两种情况分别显示不同的信息。在“找到”时,还要求显示出匹配字符串在句子中的位置,在“找到”时BX寄存器的内容为匹配字符串的首地址,将此值减到

8、句子的首地址,再将差值加1 即是所要的匹配字符串在句子中的位置,可将位置转换为十六进制。三、 实验程序DATAS SEGMENT para data mess1 db match!,13,10,$ mess2 db no match!,13,10,$ mess3 db enter keyword:,$ mess4 db enter sentence:,$ mess5 db match at location:,$ mess6 db H of the sentence,$ stoknim label byte max db 10 act db ? stokn db 10 dup(?) sente

9、nce label byte ma db 100 ac db ? sto db 100 dup(?)DATAS ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATAS,es:datasSTART: push ds sub ax,ax push ax MOV AX,DATAS MOV DS,AX mov es,ax;*输入关键字和一个句子*k: lea dx,mess3 mov ah,09 int 21h ; 显示字符串enter word lea dx,stoknim mov ah,0ah int 21h ;输入关键字到缓冲区Word push dx mov dl

10、,0dh mov ah,02h int 21h mov dl,0ah mov ah,02h int 21h ;回车换行 pop dxd: lea dx,mess4 mov ah,09 int 21h ;显示字符串enter sentence lea dx,sentence mov ah,0ah int 21h ;输入句子到缓冲区sentence push dx mov dl,0dh mov ah,02h int 21h mov dl,0ah mov ah,02h int 21h ;回车换行 pop dx;*比较查找信息* lea si,stoknim ;si指向关键字 lea di,sente

11、nce ;di指向句子 mov ax,0 mov bl,1 ;初始化bx mov cl,0 ;初始化外循环计数单元 mov al,act mov ah,ac sub ah,al add ah,1 mov cl,ah ;cl中循环次数 cmp cl,0 je nomatcha: push cx mov cl,al repnz cmpsb jz match sub di,1 sub si,2 add bl,1 pop cx dec cl cmp cl,0 jne a je nomatch;*输出信息*match: lea dx,mess1 mov ah,09h int 21h ;显示match p

12、ush dx mov dl,0dh mov ah,02h int 21h mov dl,0ah mov ah,02h int 21h ;回车换行 pop dx lea dx,mess5 mov ah,09h int 21h ;显示match at location mov al,bl and al,0fh add al,30h cmp al,3ah jl p add al,7h p: mov dl,al mov ah,02h int 21h lea dx,mess6 mov ah,09h int 21h push dx mov dl,0dh mov ah,02h int 21h mov dl,

13、0ah mov ah,02h int 21h ;回车换行 pop dx jmp wernomatch: lea dx,mess2 mov ah,09h int 21h ;显示no match push dx mov dl,0dh mov ah,02h int 21h mov dl,0ah mov ah,02h int 21h ;回车换行 pop dxwer: jmp d main endpCODES ENDS END START五、实验结果六、实验心得 本次是汇编第二个实验,相比第一个实验有更大难度,但是实验内容也有一定实际意义,这次编写代码比较费时费力但也收益良多。 具体地在实验中学习使用了

14、带前缀地串比较,学会了如何在一段字符中查找目标字符。更熟练地使用了循环程序设计,在句子位置显示部分也参照课本使用了二进制到十六进制转换,这方面知识掌握的更深入了。 这次由于时间所限,所写代码并不是十分完善,关于后续的改进,我有以下想法,上述程序,只能查找到句子中的首个关键字,即当出现 关键字为a,句子为abca时,只能找到第一个a。是由于程序设计中,当串比较match后,程序退出。所以我的改进为在显示match及在句子中位置后,继续从上述位置继续比较,一直把句子比较完才退出程序。这样会找到句子中所有关键字位置,更有实用价值。实验三 分类统计字符个数一、 实验要求程序接受用户键入一行字符(字符个

15、数不超过80个,该字符串用回车符结束),并按字母、数字、其它字符分类计数,然后将结果存入以letter、digit和other为名的存储单元中。二、 设计思路1. 先用01H功能调用接收一个字符,对照ASC码一步一步分类将各字符分入不同种类中并计数,最后用十进制数将各类字符数显示出来2. 流程图三、 实验程序DATAS SEGMENT string1 DB Input Your String: $;输入提示信息 string2 DB Digit: $ ;各类字符提示信息 string3 DB ALetter: $ string5 DB bLetter: $ string4 DB Others:

16、 $ digit DB 0 ;数字 letter DB 0 ;字母 others DB 0 ;其他DATAS ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATASSTART: mov ax,datas mov ds,ax lea dx,string1 ;显示输入提示信息 mov ah,9 int 21h mov cx,80 ;设置循环次数L1: mov ah,01h ;中断调用,单字符输入 int 21h cmp al,0dh ;若输入回车符则结束 jz over cmp al,30h jb OTHER ;若39H(9),跳转进一步比较 ja HIGHER1 j

17、mp DIGITAL ;digit+HIGHER1: cmp al,41h ;if5ah(Z),跳转继续比较 ja HIGHER2 jmp LETTER1 HIGHER2: cmp al,61h ;if7AH(z),others+ ja OTHER jmp LETTER1 ;etter+OTHER: ;others+ inc others loop L1 DIGITAL: ;digit+ inc digit loop L1 ALETTER1: ; letter+ inc Aletter loop L1 OVER: call ENDLINE ;回车换行 lea dx,string2 ;输出数字个

18、数 mov ah,9 int 21h xor ax,ax mov al,digit ;将统计的数字送AL,为输出做准备 call DISPLAY ;调用输出两位数字的子程序 call ENDLINE lea dx,string5 ;输出字母个数 mov ah,9 int 21h xor ax,ax mov al,bletter call DISPLAY call ENDLINE lea dx,string4 ;输出其他字符个数 mov ah,9 int 21h xor ax,ax mov al,others call DISPLAY mov ah,4ch int 21hENDLINE PROC

19、 NEAR ;控制输出格式,输出回车换行子程序 mov ah,2 mov dl,0ah ;换行 int 21h mov ah,2 mov dl,0dh ;回车 int 21h retENDLINE ENDPDISPLAY PROC NEAR ;输出两位数字的子程序 mov bl,10 ;10送BL div bl ;AX/BL,AL=商,AH=余数 push ax ;保存AX中的信息 mov dl,al add dl,30h mov ah,2 int 21h ;输出十位数 pop ax ;出栈送AX mov dl,ah add dl,30h mov ah,2 int 21h ;输出个位数 ret

20、DISPLAY ENDPCODES ENDS四、 实验结果 五.实验心得这次实验目的主要是学会分支程序设计,虽然分类繁琐,可是我感觉本次实验并不是太难在实验中定义了letter,digit,others三个存储单元用于记录每种符号个数。在内循环中,找出字符串属于哪类,通过与相应的ASCII码进行比较来确定相应的类别,通过比较和跳转来对不同类别的符号计数。通过改变跳转条件可以获得更加详细的分类结果。本次实验成功实现了题目的要求,可以统计输入字符类别的个数。本次试验中得到的结果仍需调用相应程序将二进制数转换为十六进制并显示出来。本实验的重点在分类,通过分支程序的角度来解决问题使问题得到简化。实验四

21、 查找电话号码一、 实验要求(1) 要求程序建立一个可存放50项的电话号码表,每项包括人名及电话号码两部分;(2) 程序可接受输入人名及相应的电话号码,并把它们加入电话号码表中;(3) 凡有新的输入后,程序可按人名对电话号码表重新排序;(4) 程序可接受需要查询电话号码的人名,并从电话号码表中查出其电话号码,再在屏幕上以如下格式显示出来。 Name tel 二、 设计说明(1)显示提示符 Input name:; (2)调用子程序 input_name 接收人名; (3)调用子程序 stor_name 把人名存入电话号码表 tel_tab 中:(4)显示提示符 Input a telephon

22、e number:;(5)调用子程序 inphone 接收电话号码,并把它存入电话号码表tel_tab中;(6)如输入已结束则调用 name_sort 子程序对电话号码表接人名排序; (7)显示提示符 Do you want a telephone number ?(Y/N);(8)回答N收退出程序; (9)回答Y则再显示提示符 name ?;(10)调用子程序 input_name接收人名;(11)调用子程序 name_search 在电话号码表中查找所要的电话号码; (12)调用子程序 printline 按要求格式显示人名及电话号码; (13)重复查号提示符直至用户不要求查号为止。三、设

23、计思路1.模块图2.主要模块流程图四、模块说明模块名输入输出功能main总控制模块用户的各种操作选择如选择是否继续插入,继续查询等各种提示信息,如提示输入姓名、号码、提示是否继续操作建立联系人号码表,对号码表人名排序,提供查询、显示功能input_name联系人的姓名到tname缓冲区无读入姓名到tname缓冲区并把不满20位部分补空格name_searchtname缓冲区的姓名查找结果放在bx寄存器在号码表查找tname缓冲区的姓名,找到则bx存放该记录的地址,否则(bx)=-1crlf无回车换行输出回车换行stor_nametname缓冲区的姓名把tname缓冲区的姓名移动到号码表,对应记

24、录数tab_len增1,endaddr增28把姓名从缓冲区移动到号码表inphone电话号码把inphone缓冲区的号码移动到号码表中读入电话号码并转存到号码表中name_sort从tab_len取出记录数,从endaddr取出最后一个记录地址。号码表中只有最后一个记录无序,前面记录有序排序对号码表进行排序(用插入排序,每次输入一个联系人后进行排序) print_all号码表的地址无显示号码表中的所有电话号码printline要显示的联系人地址存放在bx无显示单个联系人的信息五 、实验程序dataseg segment namepar label byte maxnlen db 21 actn

25、len db ? _name db 21 dup(?) phonepar label byte maxplen db 9 actplen db ? phone db 9 dup(?) crlf db 13,10,$ endaddr dw ? mess1 db enter name:,$ mess2 db enter a telephone number:,$ mess3 db Do you want a telephone number?(Y/N),$ mess4 db name?,$ mess5 db name,16 dup( ),tel,0dh,0ah,$ mess6 db Not in

26、the table.,0dh,0ah,$ mess7 db Invalid input!,0dh,0ah,$ count db 0 tel_tab db 50 dup(20 dup( ),8 dup( ) temp db 20 dup( ),8 dup( ),0dh,0ah,$ swapped db 0dataseg ends;*codeseg segmentmain proc far assume cs:codeseg,ds:dataseg,es:datasegstart: push ds sub ax,ax push ax mov ax,dataseg mov ds,ax mov es,a

27、x; cld lea di,tel_tab ;di中存放表首地址inputloop: mov ah,09h lea dx,mess1 int 21h call input_name cmp actnlen,0 ;没有输入人名时 jz a1 ;直接跳到提示是否查找的地方 cmp count,50 ;输入上限 je a1 call stor_name ;保存人名到tel_tab mov ah,09h lea dx,mess2 int 21h call input_stor_phone ;输入并保存电话号码 jmp inputloopa1: cmp count,1 jbe searchloop ;如

28、果没有输入或者输入一个 call name_sort ;排序 call disp_all ;显示所有searchloop: lea dx,mess3 mov ah,09h int 21h mov ah,01h int 21h cmp al,N je exit cmp al,n je exit cmp al,Y je showname cmp al,y je showname mov ah,09 lea dx,crlf int 21h lea dx,mess7 ;非法输入 mov ah,09h int 21h jmp searchloopshowname: mov ah,09 lea dx,crlf int 21h lea dx,mess4 ;当输入

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1