汇编语言——《子程序应用(数制转换)程序设计》实验报告

实验目的

  1. 掌握程序设计中的子程序结构;
  2. 熟练使用过程伪指令、子程序调用和返回等汇编语言的指令编写子程序;
  3. 掌握数制转换方法;
  4. 掌握利用DOS系统功能调用进行字符输入及字符输出(显示)的方法。

实验内容

1、编写十进制到十六进制转换程序。要求从键盘取得一个十进制数,然后把该数以十六进制形式在屏幕上显示出来

2、已知从BUF开始存放了10个16进制字数据,编程求出这10个数中的最大数,(将最大数存入MAX字节单元),并将其以10进制数的形式在屏幕上显示出来。

(提示:以上两题都要求采用子程序的方法)

3、从键盘上输入一行字符,如果这行字符比前一次输入的一行字符长度长,则保存该行字符,然后继续输入另一行字符;如果它比前一次输入的行短,则不保存这行字符。按下‘$’输入结束,最后将最长的一行字符显示出来。(选作)

(提示:定义数据段,包括两个变量STRING和BUFFER,格式如下:

STRING   DB  0    ;存放字符的个数
DB 80 DUP (?), 0DH,0AH,‘$’;存放前一次输入的字符串,兼作显示缓冲区
BUFFER  DB  80  ;输入字符串的缓冲区,最多输入80个字符
DB  ?
DB  80 DUP (20H)

然后利用0AH号DOS系统功能调用收入字符,用09H号系统功能调用输出。)

设计思想

1.先调用子函数decibin由键盘输入一个数字后,先减去30h把ASCII码形式转换为十进制数形式,保存在bx中,再调用子函数binihex,用十六进制形式显示bx中的数。

2.利用子函数max依次比较,将buf中10个字的最大值放到bx中,再一次除以10000,1000,100,10,并分别把余数放到bx,商放到dl,并转换为ASCII码格式,即把十六进制转为10进制,最后调用2号功能输出结果即可。

3.调用0ah功能,将输入字符放到缓冲区,并把之后输入的字符串依次与缓冲区内容相比较,若小于缓冲区内容,则被替换,直到输入$即停止输入字符串为止,输出最终存放在string中的字符串的内容。

程序代码

1

data segment         
        Str1 db 0DH,0AH,'Please input a number: ','$'
        Str2 db 0DH,0AH,'Trans:','$'        	 
data ends 
decihex segment
        assume cs:decihex,ds:data
main proc far				
         push ds       
         sub ax,ax
         push ax
         mov ax,data
         mov ds,ax
repeat:  
         lea dx,Str1  
         mov ah,09
         int 21h
         call decibin
         lea dx,Str2  
         mov ah,09
         int 21h
         call binihex
         mov dl,0ah      ;换行
         mov ah,2
         int 21h
         jmp  repeat
main endp

decibin proc near
        mov  bx,0
newchar:
        mov ah,1
        int 21h
        sub al,30h
        jl  exit          
        cmp al,9d
        jg  exit          
        cbw               
        xchg ax,bx        
        mov cx,10d
        mul cx
        xchg ax,bx        
        add bx,ax         
        jmp newchar       
exit:
        ret
decibin endp

binihex proc near
        mov ch,4
rotate: mov cl,4
        rol bx,cl
        mov al,bl
        and al,0fh
        add al,30h
        cmp al,3ah
        jl  printit
        add al,7h
printit:
        mov dl,al
        mov ah,2
        int 21h
        dec ch
        jnz rotate
        ret
binihex endp

decihex ends 
     end main

2

data segment
	buf dw 05h,0fh,15h,1fh,45h,25h,2ah,32h,3ah,3fh
data ends
code segment
	assume cs:code,ds:data
main proc far
start:
	mov ax,data
	mov ds,ax

	call max
	call convey

	mov ax,4c00h
	int 21h

main endp
max proc near
	mov bx,0
	mov cl,10
	mov ax,buf[bx]
repeat:
	add bx,2
	cmp ax,buf[bx]
	jg greater
	mov ax,buf[bx]	
greater:  
	loop repeat
	mov bx,ax
	ret
max endp
convey proc near
	mov cx,10000d
	call divid	
	mov cx,1000d
	call divid
	mov cx,100d
	call divid
	mov cx,10d
	call divid
	mov cx,1d
	call divid
ret
convey endp
divid proc near	
	mov ax,bx
	mov dx,0
	div cx
	mov bx,dx
	mov dl,al
	add dl,30h
	mov ah,2
	int 21h
ret
divid endp
code ends
	end start

3

data segment
STRING	DB  0	;存放字符的个数
	DB  80 DUP (?), 0DH,0AH,'$' ;存放前一次输入的字符串,兼作显示缓冲区

BUFFER	DB  82	;输入字符串的缓冲区,最多输入80个字符
	DB	?
	DB	80 DUP (?)
outstr db 0dh,0ah,'Longest string:','$'
data ends

code segment 
	assume cs:code,ds:data,es:data
main proc far
start:
	mov ax,data
	mov ds,ax
	mov es,ax
repeat:	
	mov ah,02h
	mov dl,0dh
	int 21h
	mov ah,02h
	mov dl,0ah
	int 21h
	lea dx,buffer
	mov ah,0ah
	int 21h
	mov al,buffer[2]
	cmp al,'$'
	jnz compare
	jmp output
compare:
	mov al,buffer[1]
	cmp al,string[0]
	jl repeat
	mov string,al
	lea si,buffer[2]
	lea di,string[1]
	mov cl,buffer[1]
	sub ch,ch
	cld
	rep movsb
	jmp repeat
output:
	lea dx,outstr
	mov ah,09h
	int 21h
	lea dx,string[1]
	mov ah,09h
	int 21h
	mov ah,4ch
	int 21h
main endp
code ends
	end start

 

结果分析

1

2

3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Starzkg

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值