北理工_汇编_实验三_字符串操作实验
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
本科实验报告
实验名称: 字符串操作实验
课程名称:
CPU 与汇编实验
实验时间: 任课教师: 实验地点:
实验教师: 实验类型: □ 原理验证
■ 综合设计
□ 自主创新
学生姓名:
学号/班级:
组 号: 无 学 院: 信息与电子 同组搭档: 无 专 业: 信息工程
成 绩:
一、实验要求和目的
1.了解汇编语言字符串处理基本流程;
2.熟悉汇编语言字符串处理基本指令的使用方法;
3.掌握利用汇编语言实现字符串处理的程序设计方法。
二、软硬件环境
1、硬件环境:计算机系统 windows;
2、软件环境:装有 MASM、DEBUG、LINK等应用程序。
三、实验涉及的主要知识
1、字符串处理基本操作流程
(1)利用 SI 寄存器保存源串首地址;
(2)利用 DI 寄存器保存目的串首地址;
(3)利用 CX 寄存器保存字符串长度;
(4)利用 CLD 或 STD 指令设置字符串处理方向;
(5)利用字符串处理指令实现相关处理。
其中,CLD 指令使 DF=0,在执行串处理指令时可使地址自动增量;STD 使 DF=1,在执行串处理指令时可使地址自动减量。
2、重复前缀指令,重复次数由计数寄存器 CX 中存放的值决定,指令每重复执行一次,计数器 CX 中值减 1,当 CX 中值减至 0 时,停止重复执行,继续执行下一条指令REP无条件重复前缀,重复串操作直到计数寄存器的内容 CX 为0为止。经常与REP 配合工作的字符串处理指令有 MOVS、STOS 和 LODS。
REPE/REPZ 判断计数寄存器的内容 CX 是否为0或ZF=0(即比较的两个操作数不等),只要满足一个则重复执行结束,否则继续执行。可以与 REPE/REPZ 配合工作的串指令有 CMPS 和SCAS。
REPNE/REPNZ 判断计数寄存器的内容是否为0或ZF=1(即比较的两个操作数相等),只要满足一个则重复执行结束,否则继续执行。可以与REPE/REPZ 配合工作的串指令有 CMPS 和SCAS。
3、字符串处理基本指令
(1)MOVS 传送指令
格式:MOVS DST,SRC或 MOVSB(传送字节)或 MOVSW(传送字)。后面两种形式需要与 REP 指令结合使用。该指令把由源变址寄存器(SRC)指向的数据段中的一个字(或字节)数据传送到由目的变址寄存器(DST)指向的附加段中的一个字(或字节)中去,同时,根据方向标志及数据格式(字或字节)对源变址寄存器和目的变址寄存器进行修改。
(2)STOS 存入串指令
格式:STOS DST 或 STOSB(存入字节)或 STOSW(存入字)。
该指令把 AL 或 AX 的内容存入由目的变址寄存器指向的附加段的某单元中,并根据方向标志(DF)和数据类型修改目的变址寄存器的内容。
(3)LODS 从串取指令
格式:LODS SRC 或 LODSB(取字节)或 LODSW(取字)。
该指令把由源变址寄存器指向的数据段中某单元的内容传送到 AL 或 AX 中,并根据方向标志和数据类型修改源变址寄存器的内容。
(4)CMPS 串比较指令
格式:CMPS SRC,DST 或 CMPSB 或 CMPSW。
该指令把由源变址寄存器指向的数据段中的一个字节或字与由目的变址寄存器所指向的附加段中的一个字节或字相减,但不保存结果,只根据结果设置条件标志。
该指令与 REPE/REPZ 或 REPNE/REPNZ 结合,可以比较两个数据串。
(5)SCAS 串扫描指令
格式:SCAS DST 或 SCASB 或 SCASW。
该指令把 AL 或 AX 的内容与由目的变址寄存器所指向的附加段中的一个字节或字进行比较,并不保存结果,只根据结果设置条件码。
该指令与 REPE/REPZ 或 REPNE/REPNZ 结合,可以从一个字符串中查找一个指定的字符。
总的来说,字符串处理可以将缓冲区中一个数据块搬至存储器的另一处,比较两个字符串是否相等,从缓冲区中一个数据块寻找某一个特定的关键字,顺次从一个缓冲区取字符或顺次向一个缓冲区存字符等。
四、实验内容与步骤
1、比较缓冲区中两字符串是否相同,相同则 AL 返回 0,不同 AL 返回 1。为了使程序的通用性比较好,字符串长度要求自动获取。(要求用字符串处理方法)
(1)程序代码
DATAS SEGMENT
BUF1 DB'ABC'
LEN1 EQU $-BUF1 ;获取字符串长度
BUF2 DB'ABD'
LEN2 EQU $-BUF2
DATAS ENDS
STACKS SEGMENT
STACKS ENDS
CODES SEGMENT
ASSUME CS:CODES,DS:DATAS,SS:STACKS
START:
MOV AX,DATAS
MOV DS,AX
MOV ES,AX
MOV CX,LEN1 ;将字符串1的长度存入CX中
CMP CX,LEN2 ;比较两字符串长度,不相等直接可判断两字符串不同
JNZ NO
MOV SI,OFFSET BUF1
MOV DI,OFFSET BUF2
REPE CMPSB ;逐个比较,相同则循环
JZ YES ;CX为零时跳出循环,说明两字符串相等
NO: MOV AL,1 ;CX不为零时跳出循环,说明两字符串不等
JMP L
YES:MOV AL,0
L: ADD AL,30H ;将AL中的‘0’与‘1’转换成可显示结果
MOV DL,AL ;显示比较结果
MOV AH,02
INT 21H
MOV AH,4CH
INT 21H
CODES ENDS
END START
(通过改变BUF1与BUF2的值,来比较不同字符串)
*本程序先将0或1返回到AL中。为显示结果方便,本程序在末段将AL值加30H进行输出。也可不加末段输出语句,直接在DEBUG时观察寄存器值来得到结果。
(2)实验结果
以字符串为“ABC”与“ABD”为例。
2、编写程序,将内存中某一区域的数据传送到另一区域。(要求用字符串处理方法)(1)程序代码
DATAS SEGMENT
BUF1 DB'ABC'
LEN1 EQU $-BUF1 ;获取字符串长度
BUF2 DB 64 DUP('$');先将BUF空间所有内容赋值为字符串结束标记
DATAS ENDS
STACKS SEGMENT
STACKS ENDS
CODES SEGMENT
ASSUME CS:CODES,DS:DATAS,SS:STACKS
START:
MOV AX,DATAS
MOV DS,AX
MOV ES,AX
MOV CX,LEN1
MOV SI,OFFSET BUF1
MOV DI,OFFSET BUF2
REP MOVSB ;逐个传送