【8086汇编(实验)】串指令和位运算

实验目的

掌握串操作指令的用法,注意DF标识位以及源串、目标串的存储和改变。
掌握位运算指令的用法,注意目标串的存储和改变。
实验要求:
(1)编写子程序
(2)在主程序中调用子程序
(3)实现主程序与子程序的参数传递
(4)实现串指令的调用。
(5)练习使用位运算

实验一

题目

写一个过程statA,该过程统计一个串(串中元素为字长)中有多少正整数,该过程有堆栈三个参数传递。
(1)串的地址
(2)串中元素的个数。(传递参数的长度为字长)
(3)保存结果的一个变量的地址。

源码

;Program:统计串中正整数的数量
;Author:Nonoas
;Date:20191210

.386
.MODEL FLAT

ExitProcess PROTO NEAR32 stdcall, dwExitCode:DWORD

INCLUDE io.h            ; header file for input/output

cr      EQU     0dh     ; carriage return character
Lf      EQU     0ah     ; line feed

.STACK  4096            ; reserve 4096-byte stack

.DATA                   ; reserve storage for data
prtInput byte cr,lf,"Original string:",0
string word 80 dup (?)
prtResult byte cr,lf,"The quantity of positive integer is:",0
result word ?

.CODE                           ; start of main program code.

strlen PROC NEAR32              ;Get the length of string
    push ebp
    mov ebp,esp
    pushf
    push ebx
    sub eax,eax
    mov ebx,[ebp+8]
whileChar:
    cmp byte ptr [ebx],0
    je endWhileChar
    inc eax
    inc ebx
    jmp whileChar
endWhileChar:
    pop ebx
    popf
    pop ebp
    ret 4
strlen ENDP

;count the number of string

statA PROC NEAR32
    push ebp
    mov ebp,esp
    pushf
    mov ecx,[ebp+14]        ;length
    mov ebx,[ebp+10]        ;addr
    mov dx,[ebp+8]         ;count
forFind:
    mov al,[ebx]
    cmp al,'0'
    jb endLoop
    cmp al,'9'
    ja endLoop
    inc dx
endLoop:
    inc ebx
loop forFind
    popf
    pop ebp
    ret 10
statA ENDP

_start:
    output prtInput
    input string,80
    lea eax,string
    push eax
call strlen     ;Get the length of string
    mov ecx,eax
    push ecx
    lea ebx,string
    push ebx
    mov dx,0
    push dx
call statA
    output prtResult
    itoa result,dx
    output result

        INVOKE  ExitProcess, 0  ; exit with return code 0
PUBLIC _start                   ; make entry point public

END                             ; end of source code

实验二

题目

从键盘输入一个数据,显示其二进制表示方式在在屏幕上。(提示用位运算指令完成)
例如:从键盘输入数据为12,它的二进制为0000 0000 0000 0000 0000 0000 0000 1100,
那么在屏幕上显示 00000000000000000000000000001100B

源码

;Program:输出一个十进制数的二进制
;Author:Nonoas
;Date:20191210
.386
.MODEL FLAT
ExitProcess PROTO NEAR32 stdcall, dwExitCode:DWORD
INCLUDE io.h            ; header file for input/output
cr      EQU     0dh     ; carriage return character
Lf      EQU     0ah     ; line feed
.STACK  4096            ; reserve 4096-byte stack
.DATA                   ; reserve storage for data
prtIN byte "Enter a number:",0
prtResult byte "Its binary value is:",cr,lf,0
prtUnits byte " B",0
strNum byte 30 dup(?)
intNum word ?
result word ?

.CODE                           ; start of main program code
_start:
    output prtIN
    input strNum,20
    atoi strNum
    mov intNum,ax
    lea ebx,strNum
    mov ecx,16
    output prtResult
forOut:
    mov dx,intNum        
    rol dx,1             ;Cycle left
    mov intNum,dx
    and dx,1             ;and the number
    itoa result,dx
    output result
loop forOut
    output prtUnits
        INVOKE  ExitProcess, 0  ; exit with return code 0
PUBLIC _start                   ; make entry point public
END                             ; end of source code

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
5.1试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来。 5.2 编写程序,从键盘接收一个小写字母,然后找出它的前导字符和后续字符,再按顺序输出 5.3 将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL、BL、CL、DL中。 5.4 试编写一程序,要求比较两个字符STRING1和STRING2所含字符是否相同,若相同则显示‘MATCH’,若不相同则显示‘NOT MATCH’。 5.5 试编写一程序,要求能从键盘接收一个个位数N,然后响铃N次。 5.6 编写程序,将一个包含有20个数据的数组M分成两个数组:正数数组P和负数数组N,并分别把这两个数组中的数据的个数显示出来。 5.7 试编制一个汇编语言程序,求出首地址为DATA的100D字数组中的最小偶数,并把它放在AX中。 5.8 把AX中存放的16位二进制数K看作是8个二进制的“四分之一字节”。试编写一个程序,要求数一下值为3(即11B)的四分之一字节数,并将该数在终端上显示出来。 5.9 试编写一汇编语言程序,要求从键盘接收一个四位的十六进制数,并在终端上显示与它等值的二进制数。 5.10 设有一段英文,其字符变量名为ENG,并以$字符结束。试编写一程序,查对单词SUN在该文中的出现次数,并以格式”SUNXXXX“显示出次数。 5.11 从键盘输入一系列以$为结束的字符,然后对其中的非数字字符进行计数,并显示出计数结果。 5.12 有一个首地址为MEM的100D字数组,试编制程序删除数组中所有为零的项,并将后续项向前压缩,最后将数组的剩余部分补上零。 5.13 在STRING到STRING+99单元中存放着一个字符,试编制一程序测试该字符中是否存在数字,如有,则把CL的第五位置1,否则置0. 5.14 在首地址为TABLE的数组中按递增次序存放着100H个16位补码数,试编写一个程序把出现次数最多的数及其出现的次数分别放在AX和CX中。 5.15 数据段中已定义了一个有N个字数据的数组M,试编写一程序求出M中绝对值最大的数,把它放在数据段的M+2n单元中,并将该数的偏移地址存放在M+2(n+1)单元中。 5.16 在首地址为DATA的字数组中,存放了100H个16位补码数,试编写一个程序求出它们的平均值放在AX寄存器中;并求出数组中有多少个数小于此平均值,将结果放在BX寄存器中。 5.17 试编写一个程序,把AX中的十六进制数转换为ASCII码,并将对应的ASCII码依次存放到MEM数组中的四个字节中,例如:当(AX)=2A49H时,程序执行完后,MEM中的4个字节的内容为39H,34H,41H和32H。 5.18 把0~100D之间的30个数存入以GRADE为首地址的30个字数组中,GRADE+i表示学号i+1的学生的成绩。另一个数组RANK为30个学生的名次表,其中RANK+i的内容是学号为i+1的学生的名次。编写一程序,根据GRADE中的学生成绩,将学生名次填入RANK数组中。 5.19 已知数组A包含15个互不相等的整数,试编写一程序,把既在A中又在B中出现的整数存在于数组中C中。 5.20 设在A,B和C单元中存放着三个数,若三个数都不是0,则求出三树之和并存放于D单元中;其中有一个数为0,则把其他两个数也清零。试编写此程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Nonoas

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

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

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

打赏作者

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

抵扣说明:

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

余额充值