实验七实验报告表
实验名称:
学号 姓名 班级: 实验时间: 20##年月12月2日
实验报告表7-1 网络中实现通信互联的主要设备和其功能
实验报告表7-2域名解析的IP路由通讯的过程
实验报告表7-3数据在网络中的IP路由通讯过程
实验报告表7-4路由器是如何确定进行转发的下一跳路径的
第二篇:北京理工大学汇编语言实验报告实验五 子程序设计实验
实验五 子程序设计实验(设计性实验)
一、实验要求和目的
1.熟悉汇编语言程序设计结构;
2.熟悉汇编语言子程序设计方法;
3.熟悉利用汇编语言子程序参数传递方法;
4.熟悉汇编语言字符串处理基本指令的使用方法;
5.掌握利用汇编语言实现字符串的输入输出程序设计方法;
6.掌握数制转换程序实现方法。
二、软硬件环境
1、硬件环境:计算机系统 windows;
2、软件环境:装有MASM、DEBUG、LINK、等应用程序。
三、实验涉及的主要知识
A) 子程序知识要点:
1、 掌握子程序的定义语句;
过程名 PROC [near/far]
过程体
RET
过程名 ENDP
2.子程序结构形式
一个完整的子程序一般应包含下列内容:
1. )子程序的说明部分
在设计了程序时,要建立子程序的文档说明,使用户能清楚此子程序的功能和调用方法.
说明时,应含如下内容:
.子程序名:命名时要名中见意.
.子程序的功能:说明子程序完成的任务;
.子程序入口参数:说明子程序运行所需参数及存放位置;
.子程序出口参数:说明子程序运行结果的参数及存放位置;
.子程序所占用的寄存器和工作单元;
.子程序调用示例;
2、 )掌握子程序的调用与返回
在汇编语言中,子程序的调用用CALL,返回用RET 指令来完成。
.段内调用与返回:调用子程序指令与子程序同在一个段内。因此只修改IP;
.段间调用与返回:调用子程序与子程序分别在不同的段,因此在返回时,需同时修改
CS:IP。
3.)子程序的现场保护与恢复
保护现场:在子程序设计时,CPU 内部寄存器内容的保护和恢复。
一般利用堆栈实现现场保护和恢复的格式:
过程名PROC [NEAR/FAR]
PUSH AX
PUSH BX
PUSH DX
POP DX
POP AX
RET
过程名 ENDP
4.子程序的参数传递方法
1. 寄存器传递参数
这种方式是最基本的参数传递方式。
2. 存储器单元传(变量)递参数
这种方法是在主程序调用子程序前,将入口参数存放到约定的存储单元中;子程序运
行时到约定存储位置读取参数;子程序执行结束后将结果也放在约定存储单元中。
3. 用堆栈传递参数
利用共享堆栈区,来传递参数是重要的的方法之一。
B) 字符、字符串输入输出知识要点:
在实际应用中,经常需要从键盘输入数据并将结果等内容显示到屏幕上,方便程序控制
及查看结果。汇编语言的数据输入和输出分成两类,一是单个字符数据的输入输出,一是字
符串数据的输入输出。都可以通过DOS 功能调用来实现,下面就分别介绍下用来实现数据输
入输出的功能调用的使用方法。
1、单个字符输入
单个字符输入可以利用DOS 的1 号功能调用来完成,使用方法为:
MOV AH,1
INT 21H
这两条语句执行后,光标会在屏幕上闪烁,等待输入数据,输入的数据以ASCII
码形式存储在AL 寄存器中。
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 号功能调用来完成,使用方法为:
STRING 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 'PLEASE 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 SEGMENT
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 HUICHE
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
MOV [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 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 ENDP
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
JA 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
stacks 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 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
;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
mov 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 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:
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
OUTPUTSTR 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: AND 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:
MOV AL,BUF[BX]
CMP AL,BUF[BX+3]
JBE CONTINUE
XCHG AL,BUF[BX+3]
MOV BUF[BX],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 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
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
add 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 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
ret
newline:
mov ah,2
mov dl,0dh
int 21h
mov ah,2
mov dl,0ah
int 21h
ret
codes ends
end start
输完组后一个数按回车后,如下:
注意:以上各题要求用子程序方法实现,每个题目至少包含2 个子程序。涉及到初始数据
的,同学们自行给出多组数据,反复加以验证各题程序。
五、实验要求与提示
1、实验要求
(1)画出各程序流程图;
(2)列出程序清单,加上适量注释;
(3)回答思考问题;
(4)记录实验结果;
(5) 完成实验报告(实验材料上的内容简写,自己的工作要详尽)。
六、思考与练习以及测评标准
1.字符串在内存中是如何存储的?
字符串在内存中以字节(byte)为单位存储,字符串包含多少字符就需要多少byte来存。汇编中定义一个字符串如下:
myString BYTE "ABCDEF",0 ;常以0作为字符串的结尾
内存中存储顺序如图所示,从箭头开始,依次向下。假设第一个地址是0000h,下一个byte的地址就是00001h,依次类推。内存中存储的是字符的二进制编码,比如A 41h=0100 0001b
2.屏幕有多个字符串显示时,如何换行?
在字符串里面包含回车(0dh)换行(0ah)字符就行了