2022年北理工_汇编_实验三_字符串操作实验 .pdf
本科实验报告实验名称:字符串操作实验课程名称:CPU 与汇编实验实验时间:任课教师:实验地点:实验教师:实验类型: 原理验证 综合设计 自主创新学生姓名:学号/班级:组号: 无学院: 信息与电子同组搭档: 无专业: 信息工程成绩:名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 7 页 - - - - - - - - - 一、实验要求和目的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)和数据类型修改目的变址寄存器的内容。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 7 页 - - - - - - - - - (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 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 7 页 - - - - - - - - - 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 ENDSEND 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 ;逐个传送名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 7 页 - - - - - - - - - MOV DX,OFFSET BUF2 ;显示传送结果MOV AH,9 INT 21H MOV AH,4CH INT 21H CODES ENDS END START (2)实验结果3、编写程序,在已知字符串中搜索特定字符 !,若找到则AL返回0,找不到AL返回1。(要求用字符串处理方法)(1)程序代码DATAS SEGMENT BUF DB ABC DE!FG LEN EQU $-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,LEN MOV DI,OFFSET BUF MOV AL, !;将要查找的字符存入AL REPNZ SCASB ;逐个查找JZ Y ;若ZF=1,则字符串中有! ,跳至 Y MOV AL,1 ;字符串中不含! ,AL=1 JMP E Y: MOV AL,0 ;字符串中含有! ,AL=0 E: ADD AL,30H ;将AL 中的 0与 1转换成可显示结果MOV DL,AL ;显示比较结果MOV AH,02 INT 21H 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 7 页 - - - - - - - - - MOV AH,4CH INT 21H CODES ENDS END START *本程序先将0 或 1 返回到 AL中。为显示结果方便,本程序在末段将AL 值加 30H 进行输出。也可不加末段输出语句,直接在DEBUG 时观察寄存器值来得到结果。(2)实验结果以字符串“ ABC DE!FG ”为例4、编写程序,统计一串字符串中字符.出现的次数。(要求用字符串处理方法);注意:同学自行给出字符串初始值加以验证以上各题程序。(1)程序代码DATAS SEGMENT BUF DB ABC. DE.F.G. LEN EQU $-BUF DATAS ENDS STACKS SEGMENT STACKS ENDS CODES SEGMENT ASSUME CS:CODES,DS:DATAS,SS:STACKS START: MOV AX,DATAS MOV DS,AX MOV BL,0 ;用于记录 . 的个数MOV ES,AX MOV CX,LEN MOV DI,OFFSET BUF MOV AL, .;将要查找的字符存入AL L1: REPNZ SCASB ;逐个查找, ZF=1时结束循环JNZ L2 ;若ZF=0,BX 不变INC BL ;若ZF=1,BX 自增一L2: CMP CX,0 ;若CX=0 ,则结束程序JA L1 ;若CX 不为零,则继续循环E: ADD BL,30H ;将BL 中的值转换成可显示结果名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 6 页,共 7 页 - - - - - - - - - MOV DL,BL ;显示计算结果MOV AH,02 INT 21H MOV AH,4CH INT 21H CODES ENDS END START (2)实验结果以字符串“ ABC. DE.F.G.”为例五、思考与练习1、如果不用字符串处理方法,而用其他方法如何实现题目2 的程序设计,比较两种方法效果?若不采用字符串处理方法,可采用如下程序段:MOV SI,0 L: MOV AL,BUF1SI MOV BUF2SI,AL INC SI LOOP L 由此见得,字符串处理方法使程序更为简洁,易于理解。六、实验心得经过本次实验,我对汇编有了一个更深入的了解,逐渐理解了其与C语言等思想的不同之处,同时也了解并练习了字符串的处理方法。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 7 页 - - - - - - - - -