北京理工大学汇编语言实验报告实验五 子程序设计实验.docx

上传人:牧羊曲112 文档编号:3337461 上传时间:2023-03-12 格式:DOCX 页数:14 大小:41.47KB
返回 下载 相关 举报
北京理工大学汇编语言实验报告实验五 子程序设计实验.docx_第1页
第1页 / 共14页
北京理工大学汇编语言实验报告实验五 子程序设计实验.docx_第2页
第2页 / 共14页
北京理工大学汇编语言实验报告实验五 子程序设计实验.docx_第3页
第3页 / 共14页
北京理工大学汇编语言实验报告实验五 子程序设计实验.docx_第4页
第4页 / 共14页
北京理工大学汇编语言实验报告实验五 子程序设计实验.docx_第5页
第5页 / 共14页
亲,该文档总共14页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《北京理工大学汇编语言实验报告实验五 子程序设计实验.docx》由会员分享,可在线阅读,更多相关《北京理工大学汇编语言实验报告实验五 子程序设计实验.docx(14页珍藏版)》请在三一办公上搜索。

1、北京理工大学汇编语言实验报告实验五 子程序设计实验实验五 子程序设计实验 一、实验要求和目的 1熟悉汇编语言程序设计结构; 2熟悉汇编语言子程序设计方法; 3熟悉利用汇编语言子程序参数传递方法; 4熟悉汇编语言字符串处理基本指令的使用方法; 5掌握利用汇编语言实现字符串的输入输出程序设计方法; 6掌握数制转换程序实现方法。 二、软硬件环境 1、硬件环境:计算机系统 windows; 2、软件环境:装有MASM、DEBUG、LINK、等应用程序。 三、实验涉及的主要知识 A) 子程序知识要点: 1、 掌握子程序的定义语句; 过程名 PROC near/far 过程体 RET 过程名 ENDP 2

2、.子程序结构形式 一个完整的子程序一般应包含下列内容: 1. )子程序的说明部分 在设计了程序时,要建立子程序的文档说明,使用户能清楚此子程序的功能和调用方法. 说明时,应含如下内容: .子程序名:命名时要名中见意. .子程序的功能:说明子程序完成的任务; .子程序入口参数:说明子程序运行所需参数及存放位置; .子程序出口参数:说明子程序运行结果的参数及存放位置; .子程序所占用的寄存器和工作单元; .子程序调用示例; 2、 )掌握子程序的调用与返回 在汇编语言中,子程序的调用用CALL,返回用RET 指令来完成。 .段内调用与返回:调用子程序指令与子程序同在一个段内。因此只修改IP; .段间

3、调用与返回:调用子程序与子程序分别在不同的段,因此在返回时,需同时修改 CS:IP。 3)子程序的现场保护与恢复 保护现场:在子程序设计时,CPU 内部寄存器内容的保护和恢复。 一般利用堆栈实现现场保护和恢复的格式: 过程名PROC NEAR/FAR PUSH AX PUSH BX PUSH DX POP DX POP AX RET 过程名 ENDP 4.子程序的参数传递方法 1 寄存器传递参数 这种方式是最基本的参数传递方式。 2 存储器单元传递参数 这种方法是在主程序调用子程序前,将入口参数存放到约定的存储单元中;子程序运 行时到约定存储位置读取参数;子程序执行结束后将结果也放在约定存储单

4、元中。 3 用堆栈传递参数 利用共享堆栈区,来传递参数是重要的的方法之一。 B) 字符、字符串输入输出知识要点: 在实际应用中,经常需要从键盘输入数据并将结果等内容显示到屏幕上,方便程序控制 及查看结果。汇编语言的数据输入和输出分成两类,一是单个字符数据的输入输出,一是字 符串数据的输入输出。都可以通过DOS 功能调用来实现,下面就分别介绍下用来实现数据输 入输出的功能调用的使用方法。 1、单个字符输入 单个字符输入可以利用DOS 的1 号功能调用来完成,使用方法为: MOV AH,1 INT 21H 这两条语句执行后,光标会在屏幕上闪烁,等待输入数据,输入的数据以ASCII 码形式存储在AL

5、 寄存器中。 2、单个字符输出 单个字符输出可利用DOS2 号功能调用来完成,使用方法为: MOV DL,? MOV AH,2 INT 21H 单个字符输出需要把要输出字符的ASCII 码放在DL 寄存器中。 3、字符串输入 从键盘输入一串字符串可以利用DOS 的10 号功能调用来完成,使用方法为: BUF DB 50 ;预定义可以输入的最大字符个数 DB ? ;实际输入字符个数,根据输入自动统计 DB 50 DUP (?) ;存放输入字符串数据缓冲区 LEA DX,BUF MOV AH,10 INT 21H 4、字符串输出 字符串输出可由DOS 9 号功能调用来完成,使用方法为: STRIN

6、G DB HELLO$ LEA DX,STRING MOV AH,9 INT 21H C) 表的处理知识要点: 表的处理在实际数据处理中应用较为广泛,主要有排序、搜索、插入和删除等操作。有 一些常用的冒泡法、对分搜索法等需要掌握。 四、实验内容与步骤 1、从键盘输入一串字符串到内存中,在该字符串的某一个指定位置,插入某 一字符或删除某一字符,并显示操作后的字符串。 源代码如下: DATAS SEGMENT BUF DB 20 DB ? DB 20 DUP(0) DB 6 DUP(0) STRING0 DB PLEASE INPUT STRINGS:,0AH,0DH,$ STRING1 DB P

7、LEASE CHOOSE INSERT OR DELETE:1.INSERT 2.DELETE,0AH,0DH,$ STRING2 DB PLEASE INPUT THE ADDRESS TO DELETE,0AH,0DH,$ STRING3 DB PLEASE INPUT THE ADDRESS TO INSERT,0AH,0DH,$ STRING4 DB PLEASE INPUT THE SYMBOL TO INSERT,0AH,0DH,$ BUF1 DB 20 DUP(0),$ INSER DB 0,0 DELE DB 0 NUMBER DB 0 DATAS ENDS STACKS SE

8、GMENT DB 256 DUP(0) STACKS ENDS CODES SEGMENT assume CS:CODES,DS:DATAS,SS:STACKS START: MOV AX,DATAS MOV DS,AX MOV ES,AX LEA BX,STRING0 CALL OUTPUTSTR ;输出字符串0 CALL INPUTSTR ;输入字符串 CALL HUICHE MOV AL,BUF+1 MOV NUMBER,AL LEA BX,STRING1 CALL OUTPUTSTR ;输出字符串1 MOV AH,01H ;输入1或2 INT 21H CMP AL,1 CALL HUI

9、CHE JZ IN1 LEA BX,STRING2 ;为2,执行删除操作 CALL OUTPUTSTR MOV AH,01H INT 21H AND AL,0FH MOV DELE,AL CALL HUICHE CALL DELETE CALL MOVE1 LEA BX,BUF1 CALL OUTPUTSTR CALL HUICHE JMP FINAL IN1:LEA BX,STRING3 ;执行插入操作 CALL OUTPUTSTR MOV AH,01H INT 21H AND AL,0FH LEA BX,STRING4 CALL OUTPUTSTR MOV AH,01H INT 21H M

10、OV INSER+1,AL CALL HUICHE CALL INSERT CALL MOVE1 LEA BX,BUF1 CALL OUTPUTSTR FINAL: MOV AH,4CH INT 21H INPUTSTR PROC NEAR ;输入函数 LEA DX,BUF MOV AH,0AH INT 21H RET INPUTSTR ENDP HUICHE PROC NEAR ;回车换行函数 MOV DL,0DH MOV AH,02H INT 21H MOV DL,0AH MOV AH,02H INT 21H RET HUICHE ENDP OUTPUTSTR PROC NEAR MOV

11、DX,BX ;输出字符串函数 MOV AH,09H INT 21H RET OUTPUTSTR ENDP DELETE PROC NEAR ;删除函数 LEA BX,BUF MOV DI,BX ADD DI,2 MOV AL,DELE XOR AH,AH ADD DI,AX XOR CH,CH MOV CL,NUMBER ADD BX,CX ADD BX,1 MOVE: CMP BX,DI JE LADE MOV DH,DI+1 MOV DI,DH INC DI CMP BX,DI JNE MOVE LADE: MOV BYTE PTR DI,$ DEC NUMBER RET DELETE E

12、NDP MOVE1 PROC NEAR ;移动复制函数 LEA SI,BUF ADD SI,2 LEA DI,BUF1 MOV CL,NUMBER XOR CH,CH REP MOVSB MOV BYTE PTR DI,$ RET MOVE1 ENDP INSERT PROC NEAR ;插入函数 LEA BX,BUF MOV DI,BX MOV AL,INSER XOR AH,AH ADD DI,AX INC DI XOR CH,CH MOV CL,NUMBER ADD BX,CX ADD BX,1 INS1: MOV DH,BX MOV BX+1,DH DEC BX CMP BX,DI J

13、A INS1 INC BX MOV AL,INSER+1 MOV BX,AL INC NUMBER RET INSERT ENDP CODES ENDS END START 运行结果如下: 其中在最开始输入1是添加,紧接着输入位置和要添加的字符,功能2是删除,接着输入删除的位置,如上图所示 2、编写程序把从键盘输入的四位十六进制数,转换为十进制形式在屏幕上打印出来。 datas segment num2 db 0,0,0,0 num22 dw 0 tempio db 0 temp dw 0 tab db 0123456789abcdef datas ends stacks segment st

14、acks ends codes segment assume ds:datas,ss:stacks,cs:codes start: mov ax,datas mov ds,ax mov ax,0 lea si,num2 call input mov al,tempio sub al,0 mov ds:si,al inc si call input mov al,tempio sub al,0 mov ds:si,al inc si call input mov al,tempio sub al,0 mov ds:si,al inc si call input mov al,tempio sub

15、 al,0 mov ds:si,al call newline lea si,num2 mov cx,4 mov dx,0ah l2: cmp ds:si,dl jb l21 mov al,ds:si sub al,7 mov ds:si,al l21: inc si loop l2 lea si,num2 mov ah,ds:si mov cx,4 shl ah,cl inc si mov bl,ds:si add ah,bl inc si mov al,ds:si mov cx,4 shl al,cl inc si mov bl,ds:si add al,bl mov num22,ax ;

16、1 mov dx,0 mov cx,2710h div cx mov temp,dx add ax,0 mov tempio,al call output mov ax,temp ;2 mov dx,0 mov cx,3e8h div cx mov temp,dx add ax,0 mov tempio,al call output mov ax,temp ;3 mov dx,0 mov cx,64h div cx mov temp,dx add ax,0 mov tempio,al call output mov ax,temp ;4 mov dx,0 mov cx,0ah div cx m

17、ov temp,dx add ax,0 mov tempio,al call output mov ax,temp ;5 add ax,0 mov tempio,al call output call newline call newline mov ah,4ch int 21h input: mov ah,1 int 21h mov tempio,al ret newline: mov ah,2 mov dl,0dh int 21h mov ah,2 mov dl,0ah int 21h ret output: mov ah,2 mov dl,tempio int 21h ret codes

18、 ends end start 运行结果如下: 3、从键盘输入十个2 位十进制数到内存中,按从小到大排序,然后 把该数以十六进制形式在屏幕上打印出来。 源代码如下: DATAS SEGMENT BUF DB 40 DB ? DB 40 DUP(0) SHUZI DB 10 DUP(0) BIAO DW 0 STRING DB PLEASE INPUT 10 NUMBERS:$ DATAS ENDS STACKS SEGMENT STA DW 20H DUP(0) STACKS ENDS CODES SEGMENT ASSUME CS:CODES,DS:DATAS,SS:STACKS START

19、: MOV AX,DATAS MOV DS,AX MOV AX,STACKS MOV SS,AX LEA BX,STRING ;输出提示 CALL OUTPUTSTR CALL HUICHE CALL INPUT ;输入10个十进制数 CALL HUICHE CALL EXCHASC ;将ASC 码转换 CALL RANK ;将其排序 LEA SI,BUF ADD SI,5 MOV DI,10 ABC: MOV AL,SI CALL PUTABYTE ;将16进制数输出 CALL KONGGE ADD SI,3 DEC DI JNZ ABC MOV AH,4CH INT 21H OUTPUTS

20、TR PROC NEAR ;输出字符串 MOV DX,BX MOV AH,09H INT 21H RET OUTPUTSTR ENDP INPUT PROC NEAR ;输入字符串函数 LEA DX,BUF MOV AH,0AH INT 21H RET INPUT ENDP HUICHE PROC NEAR ;回车换行 MOV DL,0DH MOV AH,02H INT 21H MOV DL,0AH MOV AH,02H INT 21H RET HUICHE ENDP EXCHASC PROC NEAR ;ASC码转换函数 LEA SI,BUF ADD SI,2 MOV CX,10 S: AN

21、D BYTE PTR SI,0FH INC SI AND BYTE PTR SI,0FH ADD SI,2 LOOP S ;变成十进制码 LEA SI,BUF ADD SI,2 MOV BL,10 MOV CX,10 S1: MOV AL,SI MUL BL ;变成实际数字 ADD AL,SI+1 MOV SI,AL ADD SI,3 LOOP S1 RET EXCHASC ENDP RANK PROC NEAR ;排序函数 LEA SI,BUF ADD SI,2 LEA DI,BUF ADD DI,5 MOV CX,10 MOV AL,SI S2: MOV DI,CX MOV BX,2 S3

22、: MOV AL,BUFBX CMP AL,BUFBX+3 JBE CONTINUE XCHG AL,BUFBX+3 MOV BUFBX,AL CONTINUE: ADD BX,3 LOOP S3 MOV CX,DI LOOP S2 RET RANK ENDP PUTABYTE PROC NEAR;显示16进制数字 MOV CL,4 MOV DL,AL SHR DL,CL MOV BIAO,AX CALL EXCHANGEDISP MOV AX,BIAO MOV DL,AL AND DL,0FH CALL EXCHANGEDISP RET PUTABYTE ENDP EXCHANGEDISP

23、PROC NEAR CMP DL,9 JA NOTDIG OR DL,30H JMP FINAL NOTDIG: ADD DL,37H FINAL: MOV AH,02H INT 21H RET EXCHANGEDISP ENDP KONGGE PROC NEAR ;输出空格函数 MOV DL,20H MOV AH,02H INT 21H RET KONGGE ENDP CODES ENDS END START 运行结果如下: 4、英文人名排序。从终端键入20 个人名,当所有人名都键入后,按字母上升的次序将人名 排序,并在屏幕上显示已经排好序的人名。 源代码如下: datas segment

24、buf4 db 460 dup($) bp4 dw 20 dup(0) mark db num41 dw 20 num42 dw 19 temp dw 0 datas ends stacks segment stacks ends codes segment assume ds:datas,ss:stacks,cs:codes start: mov ax,datas mov ds,ax mov es,ax mov ax,stacks mov ss,ax lea si,buf4 lea di,bp4 mov cx,20 l4: mov al,20 mov ds:si,al mov dx,si a

25、dd dx,2 mov es:di,dx inc di inc di call gets add si,23 loop l4 l41: lea si,bp4 mov ax,19 mov num42,ax l42: mov di,ds:si+2 mov temp,si mov ax,ds:si mov si,ax mov cx,20 repe cmpsb js skip41 mov si,temp mov ax,ds:si xchg ax,ds:si+2 mov ds:si,ax skip41: mov si,temp inc si inc si mov cx,num42 dec cx mov

26、num42,cx inc cx loop l42 mov cx,num41 dec cx mov num41,cx inc cx loop l41 call newline lea di,bp4 mov cx,20 l43: mov temp,cx mov si,es:di call puts call newline inc di inc di mov cx,temp loop l43 mov ah,4ch int 21h gets: mov ah,10 mov dx,si int 21h call newline ret puts: mov ah,9 mov dx,si int 21h r

27、et newline: mov ah,2 mov dl,0dh int 21h mov ah,2 mov dl,0ah int 21h ret codes ends end start 输完组后一个数按回车后,如下: 注意:以上各题要求用子程序方法实现,每个题目至少包含2 个子程序。涉及到初始数据 的,同学们自行给出多组数据,反复加以验证各题程序。 五、实验要求与提示 1、实验要求 画出各程序流程图; 列出程序清单,加上适量注释; 回答思考问题; 记录实验结果; (5) 完成实验报告。 六、思考与练习以及测评标准 1字符串在内存中是如何存储的? 字符串在内存中以字节为单位存储,字符串包含多少字符就需要多少byte来存。汇编中定义一个字符串如下: myString BYTE ABCDEF,0 ;常以0作为字符串的结尾 内存中存储顺序如图所示,从箭头开始,依次向下。假设第一个地址是0000h,下一个byte的地址就是00001h,依次类推。内存中存储的是字符的二进制编码,比如A 41h=0100 0001b 2屏幕有多个字符串显示时,如何换行? 在字符串里面包含回车(0dh)换行(0ah)字符就行了

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号