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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

汇编语言编程实验报告.pdf

1、 汇编语言编程 实验报告 学号: 姓名: 成绩: - 2 -目录 一、实验一: . 错误!未定义书签。 二、实验二: . 4 三、实验三: . 8 四、实验四: 10 五、实验五: . 错误!未定义书签。 六、实验六: 19 七、汇编实验总结 23 - 3 -实验一 一 实验题目 【汇编语言补充作业T20】编写完整程序,利用DOS系统功能调用,从键盘输入一个字符串,并将该字符串从屏幕上换行后并输出。 二 程序流程及思路 实现字符串输入,需要分成三个步骤: 1、在数据段中定义一个缓存区为存放字符串做准备; 2、DOS系统功能调用0AH号子功能,(DS:DX)= 输入缓冲区首址; 3、在输入的字符

2、串尾加上$字符,以作为输出结束条件。 实现字符串输出,则需要注意的问题是: 1、缓冲区第三个字节才开始存放输入的字符,前两个字节分别存放缓冲区长度和字符串实际字符数; 2、输出回车换行可利用字符串:CR DB 0AH,0DH,$。 三 源程序清单 DATA SEGMENT N EQU 50 MAXLEN DB N ;缓冲区字符的最大长度 ACTLEN DB ? ;实际字符个数 STRING DB N DUP(?) ;字符空间 CR DB 0AH,0DH,$ DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK START: MOV AX,

3、DATA MOV DS,AX LEA DX,MAXLEN MOV AH,0AH INT 21H ;字符串输入 MOV AH,09H LEA DX,CR INT 21H ;回车换行 MOV BL,MAXLEN+1 ;取实际的字符长度 MOV BH,0 LEA SI,MAXLEN+2 ;取字符开始的首地址 - 4 -MOV BYTE PTR SI+BX,$ ;输出结尾要加上$ MOV DX,SI ;把开始存放字符的首地址赋给DX MOV AH,09H INT 21H MOV AH,4CH INT 21H CODE ENDS END START 四 结果拷屏 - 5 -实验二 一. 实验题目 【汇编

4、语言补充作业T23】假设CX:BX中存放了4为非压缩的BCD码表示的十进制数4386,请编写完整程序将这个数转化成2进制数并存放到DI寄存器中。 二. 程序流程及思路 首先,要解决以上问题需分三个步骤进行: 1、将CX:BX中的非压缩BCD码调整成压缩BCD码。这有两种方法: a、利用非压缩BCD码调整指令AAD,达到以上目的; b、利用移位指令,将两个非压缩BCD码进行整合,达到以上目的; (注:以下程序采用b方法) 2、将调整后的压缩BCD码转化为十进制数。调整后b3b2=43,b1b0=86。转化方法为b3b2*100+b1b0 DI。计算结果送入DI寄存器中。 由于100=64+32+

5、4,因此考虑用移位指令进行BCD码的乘法运算。 3、利用移位指令编写一段代码进行结果输出,以便于在屏幕上直接进行核对检验。 三源程序清单 DATA SEGMENT DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK start: mov ch,04 mov cl,03 mov bh,08 mov bl,06 ; mov al,ch mov ah,0 shl ax,1 ;ch位乘10(10=8+2) mov si,ax shl ax,1 shl ax,1 add ax,si ; mov ch,0 add ax,cx - 6 -mov dx

6、,ax ;dx=43 shl dx,1 shl dx,1 mov ax,dx shl dx,1 shl dx,1 shl dx,1 add ax,dx shl dx,1 ; add dx,ax ;dx乘以100(100=64+32+4) mov al,bh mov ah,0 mov si,0 shl ax,1 ;bh位乘10 mov si,ax shl ax,1 shl ax,1 add ax,si ; mov bh,0 add ax,bx add dx,ax mov di,dx show: mov cl,4 ;该段进行结果输出检验 mov bx,dx shr bh,cl mov dl,bh

7、add dl,30h mov ah,2 int 21h ;1位 mov bh,dh and bh,0Fh mov dl,bh add dl,30h mov ah,2 int 21h ;2位 mov dh,bl shr dh,cl mov dl,dh add dl,30h - 7 -mov ah,2 int 21h ;3位 mov dh,bl and dh,0Fh mov dl,dh add dl,30h mov ah,2 int 21h ;4位 mov ah,4ch int 21h code ends end start 五 结果拷屏 输出结果为1122十六进制,将题目中4386换成4096,

8、输出如下,为1000十六进制: - 8 - 9 -实验三 一实验题目 【汇编语言补充作业T22】已知有以下数据段定义: NUM DW 3570 STRING DB 5 DUP(20H),$;20H为空格的ASCII码 请编写完整程序,在屏幕上以十进制的形式将 NUM这个数打印出来,可以借助STRING这个字符串。(NUM这个数可以定义为一个任意字型数) 二程序流程及思路 考虑到NUM在寄存器中以十六进制数的形式进行存放,转化成十进制数可能最大值为65535,则输出刚好输出的十进制数位数为5位。 因此,需要除以10000d,1000d,100d,10d,1d来分别取出该数各位数值,并在屏幕上连续

9、打印。其过程为: 1、将NUM先存入寄存器SI中,除数为10000d; 2、除法完成后,商直接输出,余数保留并且存入SI中; 3、依次将除数换成1000d,100d,10d,1d,重复2操作,直到程序结束。 另外,程序打印每一位所执行的动作需要重复五次,因此将该过程写成一个子程序(chufa)进行调用,可以简化代码,使得程序可读性更强,程序健壮性更好。 三源程序清单 DATA SEGMENT NUM DW 3570 DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,SS:STACK start: MOV AX,DATA MOV DS,AX mov si

10、,num mov cx,10000d call chufa mov cx,1000d call chufa mov cx,100d call chufa mov cx,10d call chufa mov cx,1d - 10 - call chufa mov ah,4Ch int 21h chufa: mov ax,si ;si 存储的是要输出的十进制数据 mov dx,0 div cx mov si,dx ;余数赋给si 寄存器,为下一步出发做准备 mov dl,al add dl,30h mov ah,2 int 21h ;除法的商直接输出 ret code ends end start

11、 四结果拷屏 以上为NUM=3570d时程序输出结果为03570,若将NUM改为1122H,则输出如下,结果为04386: - 11 - 12 - 实验四 一实验题目 【汇编语言补充作业T13】请编写完整程序在一个升序字节数组中查找数N,找到后将此数从数组中删除,并使得CF=0;没找到返回CF=1。数组的首地址和末地址为A_HEAD和A_END。 二程序流程及思路 删除升序数组中的一个数N的关键步骤是将这个数搜索出来。若搜索到,则进行删除,然后对整个数组进行调整;若未搜索到,则无操作动作。其中进行搜索的方法为逐个比较。 程序流程图如下: 开始 初始化数组ARRAY_HEAD,ARRAY_END

12、,目标数N BXARRAY_HEAD, BX=ARRAY_END BX=N DELETE:CF0,ARRAY_ENDARRAY_END-1,调整 EXIT:CF1 BXBX+1 结束 Y Y N N - 13 - 三源程序清单 DATA SEGMENT ARRAY DB 1,2,3,4,5,6,7,8,9,0 LENG EQU $-ARRAY ARRAY_END DW ? ARRAY_HEAD DW ? NUM DB 5 DATA ENDS STACK SEGMENT STACK STACK ENDS CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK S

13、TART: MOV AX,DATA MOV DS,AX MOV AL,LENG CBW MOV BX,OFFSET ARRAY MOV ARRAY_HEAD,BX ADD AX,BX MOV DI,AX DEC DI MOV ARRAY_END,DI MOV AX,0 MOV AL,NUM L1: MOV DL,0 MOV DL,BX CMP DL,AL ;当前数与NUM进行比较 JNE L2 ;不相等跳转至L2 JMP DELETE ;相等跳转至DELETE L2: INC BX CMP BX,ARRAY_END JBE L1 ;指针+1,并循环 STC JMP EXIT DELETE:MO

14、V DI,ARRAY_END SUB DI,BX - 14 - MOV CX,DI DEL: MOV DX,BX+1 ;将BX之后的数依次前移一位 MOV BX,DX INC BX LOOP DEL DEC ARRAY_END ;删除后ARRAY_END前移 CLC JMP EXIT EXIT: MOV CX,0 MOV CX,ARRAY_END MOV AX,OFFSET ARRAY SUB CX,AX INC CX MOV BX,0 SHOW: MOV DL,ARRAY+BX ;将删除后数组元素打印以检验 ADD DL,30H MOV AH,2 INT 21H INC BX LOOP SH

15、OW MOV AH,4CH INT 21H CODE ENDS END START 四结果拷屏 - 15 - 以上输出为在1、2、3、4、5、6、7、8、9、0数组中删去N=5的结果 调用debug-t命令可以查看CF标志位状态: 可见,CF位为0,若当N=10,在数组里未找到目标数,则结果为: 可见数组元素不变,且CF=1 - 16 - 实验五 一实验题目 【汇编语言补充作业T14】请编写完整程序从键盘读取字符,如果是十进制的09,则在屏幕上输出该数的八位二进制码,并将数字依次存放到BUF开头的数组中;如果读取的字符是Q或者q,则程序退出;其他情况在屏幕上打印“You must input

16、0-9 or q or Q”。 (如输入的字符是9,则输出00001001) 提示:输出一个数的2进制形式应该从最高位开始输出,可以将此段程序定义为一个过程。 二程序流程及思路 总体流程: 1、利用DOS系统功能调用21H 的01号子功能读取键盘输入的一个字符x,换行,然后将x与0、9的ASCII码进行比较,若在09范围内,则跳至2;不在该范围内跳至3; 2、打印该数的二进制形式,将该数存入数组BUF中,换行,跳至1; 3、将x与Q、q的ASCII码进行比较,若相等,则打印数组内容,退出程序;否则,跳至4; 4、打印字符串“You must input 0-9 or q or Q”,换行,跳至

17、1; 由以上过程看出,程序的唯一退出条件为输入字符q或Q。 流程图如下图: 二进制形式打印定义的过程如下: 初始化:除数A=128(2的7次方),被除数为B 1、B除以A,打印商,B余数,AA/2。若A=1,跳至2;否则,重复1; 2、退出打印。 另外,程序定义变量 B_END作为数组的尾指针,当符合输出规则,将输入的数存放入数组BUF中,尾指针后移一位。这样定义便于在输出数组的时候定制结束条件。 程序中定义数组的大小20个字节。 - 17 - 三源程序清单 DATA SEGMENT MESSAGE DB You must input 0-9,or“q“or“Q“,$ CR DB 0AH,$

18、BUF DB 20 DUP(0) B_END DW ? NUM DB 2 DATA ENDS STACK SEGMENT STACK STACK ENDS 开始 初始化数组尾指针B_END X=0 X=q或X=Q ERROR:打印错误提示 以二进制形式打印X B_END X B_ENDB_END+1 打印数组元素 结束 N Y N Y 读取键盘输入的字符X - 18 - CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK START: MOV AX,DATA MOV DS,AX MOV AX,OFFSET BUF ;空数组时尾指针指向数组起始地址 MOV

19、B_END,AX DEC B_END MOV AX,0 L: MOV AH,1 ;输入字符 INT 21H CMP AL,30H JB ERROR ;小于30H,跳转至ERROR CMP AL,39H JBE NEXT ;=30H且=1 N进栈 NN-1 ERROR 结束 Y N FAC递归调用 弹出N FACN*FAC 递归返回 N=q Y N - 23 - CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK START: MOV AX,DATA MOV DS,AX L: MOV AH,1 INT 21H CMP AL,31H ;判断输入的字符是否合法

20、JB ERROR CMP AL,36H JA ERROR SUB AL,30H CALL FAC MOV RESULT,DX MOV SI,DX CALL CRLF ;换行 MOV CX,1000d ;以十进制数的形式打印 CALL SHOW MOV CX,100d CALL SHOW MOV CX,10d CALL SHOW MOV CX,1d CALL SHOW CALL CRLF ;换行 MOV DX,RESULT ;还原DX的值 JMP L SHOW PROC MOV AX,SI ;si 存储的是要输出的十进制数据 MOV DX,0 DIV CX MOV SI,DX ;余数赋给si 寄

21、存器,为下一步出发做准备 MOV DL,AL ADD DL,30h MOV AH,2 INT 21h ;除法的商直接输出 RET SHOW ENDP CRLF PROC - 24 - PUSH AX ;数据保护 PUSH DX MOV AH,9 ;换行 LEA DX,CR INT 21H POP DX POP AX RET CRLF ENDP FAC PROC ;入口参数AL,出口参数N!=DX CMP AL,0 JNZ F1 MOV DX,1 RET F1: PUSH AX DEC AL CALL FAC ADD1: POP CX CALL MULT RET FAC ENDP MULT PROC MOV AL,CL MUL DL MOV DX,AX RET MULT ENDP ERROR: CMP AL,q ;输入q字符退出 JZ EXIT CALL CRLF ;换行 MOV AH,9 ;输出错误提示 LEA DX,MESSAGE INT 21H CALL CRLF ;换行 JMP L EXIT: MOV AH,4Ch ;退出程序 INT 21h CODE ENDS END START - 25 - 四结果拷屏

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报