北京理工大学语言实验报告实验三字符串操作实验

上传人:第*** 文档编号:61718678 上传时间:2018-12-10 格式:DOCX 页数:15 大小:200.99KB
返回 下载 相关 举报
北京理工大学语言实验报告实验三字符串操作实验_第1页
第1页 / 共15页
北京理工大学语言实验报告实验三字符串操作实验_第2页
第2页 / 共15页
北京理工大学语言实验报告实验三字符串操作实验_第3页
第3页 / 共15页
北京理工大学语言实验报告实验三字符串操作实验_第4页
第4页 / 共15页
北京理工大学语言实验报告实验三字符串操作实验_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《北京理工大学语言实验报告实验三字符串操作实验》由会员分享,可在线阅读,更多相关《北京理工大学语言实验报告实验三字符串操作实验(15页珍藏版)》请在金锄头文库上搜索。

1、实验三字符串操作实验一、实验目的1)熟悉串操作指令的功能与应用;2)掌握串操作指令的寻址方式及使用方法,编写常用的字符串处理程序;3)了解汇编语言字符串处理基本流程;二、实验软硬件环境1)硬件环境:惠普64位一体化计算机及局域网;2)软件环境:windows8,红蜘蛛管理系统,MASMforWindows。三、实验相关知识1)字符串操作流程w SI寄存器保存源串首地址;w DI寄存器保存目的串首地址;w CX寄存器保存字符串长度;w CLD或STD指令设置字符串处理方向;w 当CLD指令使DF=0,在执行串处理指令时可使地址自动增量;STD使DF=1,在执行串处理指令时可使地址自动减量。2)重

2、复前缀指令w 重复次数由计数寄存器CX中存放的值决定,指令每重复执行一次,计数器CX中值减1,当CX中值减至0时,停止重复执行,继续执行下一条指令。w 当REP无条件重复前缀,重复串操作直到计数寄存器的内容CX为0为止。经常与REP配合工作的字符串处理指令有MOVS、STOS和LODS。w 当REPE/REPZ判断计数寄存器的内容CX是否为0或ZF=0(即比较的两个操作数不等),只要满足一个则重复执行结束,否则继续执行。可以与REPE/REPZ配合工作的串指令有CMPS和SCAS。w 当REPNE/REPNZ判断计数寄存器的内容是否为0或ZF=1(即比较的两个操作数相等),只要满足一个则重复执

3、行结束,否则继续执行。可以与REPE/REPZ配合工作的串指令有CMPS和SCAS。3)字符串操作指令w lodsb、lodsw:把DS:SI指向的存储单元中的数据装入AL或AX,然后根据DF标志增减SI;w stosb、stosw:把AL或AX中的数据装入ES:DI指向的存储单元,然后根据DF标志增减DI;w movsb、movsw:把DS:SI指向的存储单元中的数据装入ES:DI指向的存储单元中,然后根据DF标志分别增减SI和DI;w scasb、scasw:把AL或AX中的数据与ES:DI指向的存储单元中的数据相减,影响标志位,然后根据DF标志分别增减SI和DI;w cmpsb、cmps

4、w:把DS:SI指向的存储单元中的数据与ES:DI指向的存储单元中的数据相减,影响标志位,然后根据DF标志分别增减SI和DI;w rep:重复其后的串操作指令。重复前先判断CX是否为0,为0就结束重复,否则CX减1,重复其后的串操作指令。主要用在MOVS和STOS前。一般不用在LODS前。上述指令涉及的寄存器:段寄存器DS和ES、变址寄存器SI和DI、累加器AX、计数器 CX涉及的标志位:DF、AF、CF、OF、PF、SF、ZF。4、 实验内容1) 编写程序,比较两个字符串BUF1和BUF所含的字符是否相同,相同则AL返回0,不同AL返回1,字符串长度要求自动获取,要求用字符串处理方法。提示:

5、输入两个字符串之后,将串操作所必须的寄存器等参数设置好,然后使用串操作指令进行从头到尾的比较,两个字符串相等的条件是串长度相等且对应的字符相同。(I)实验框图(II)实验代码DATAS SEGMENT BUF1 DB ABCDEFGH COUNT1 EQU $-BUF1 ;利用EQU指令,自动获取字符串长度 DATAS ENDSEXTRA SEGMENT ;定义附加段,即ES段 BUF2 DB ABCDEFGH COUNT2 EQU $-BUF2 ;功能同BUF1EXTRA ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATAS,ES:EXTRASTART: MO

6、V AX,DATAS MOV DS,AX MOV AX,EXTRA MOV ES,AX LEA SI,BUF1 ;把源操作串的地址放在SI中 LEA DI,BUF2 ;把目的操作串的地址放在DI中 MOV CX,COUNT1 CMP CX,COUNT2 ;先比较BUF1、BUF2的长度 JNZ EXIT1 ;长度不一样,字符串不同,跳转到EXIT1 CLD ;设置字符串操作方向 REPE CMPSB ;逐个字符比较 JNZ EXIT1 ;一旦有不同的字符,跳转到EXIT1 MOV AL,0 ;若全部相同,则字符串相同,返回AL=0 JMP EXIT2 EXIT1: MOV AL,1 ;当字符串

7、不同时,返回AL=1 EXIT2: MOV AH,4CH INT 21HCODES ENDSEND START(III)实验结果序号BUF1BUF2AL1ABCDEFGHABCDEFGH02ABCABCDE13ABCABD1(IV)实验结果分析序号1中,程序先经过比较字符串长度,相等后再逐一判断每个字符,确定都相等后,返回AL=0;序号2中,比较字符串长度已经发现不相等,所以返回AL=1;序号3中,比较了字符串长度,发现相等,进一步比较字符,循环到最后一个字符时,不相等,所以AL=1.2) 编写程序,设有一字符串存放在以BUF为首址的数据区中,其最后一字符$作为结束标志,计算该字符串的长度并输

8、出。提示:从串的第一个字符开始统计,直到遇到定义的字符串结束符为止,看看在这个过程中总共有多少个字符,即求得串的长度。(I)实验框图(II)实验代码DATAS SEGMENT BUF DB TBE123000000 $ DATAS ENDSEXTRA SEGMENT CHAR DB $ ;ES段设置待比较的字符$EXTRA ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATAS,ES:EXTRASTART: MOV AX,DATAS MOV DS,AX MOV AX,EXTRA MOV ES,AX LEA SI,BUF ;获取BUF的地址 L:MOV AL,SI

9、SCASB CHAR JNZ EXIT1 JZ EXIT2 EXIT1: INC SI ;不是$,计数器加1,同时字符串后移一位 JMP L EXIT2: DEC SI ;SI多加了一个1 MOV AX, SI MOV BL,10 DIV BL ;考虑SI是两位数的情况 MOV DX,AX ADD DX,3030H ;把数字转化为ASCII码 MOV AH,02H INT 21H ;打印低位 MOV DL,DH MOV AH,02H INT 21H ;打印高位 MOV AH,4CH INT 21HCODES ENDS END START(III)实验结果序号字符串屏幕输出结果1123456$

10、0620123456789$ 10(IV)实验结果分析序号1:L循环了6次,查找到$,故SI等于6,直接用DOS的2号功能打印出字符2,注意 DL里的数字2转化为“字符2的ASCII码”,加上30H即可;序号2:循环十次,主要是逻辑上的两位数,要分离处理,因为2号功能只能打印一个字符;考虑除以10,得到商作为十位,余数作为个位。此时还是二进制,加上3030H,在打印即可。3) 编写程序,将内存中BUF1某一区域的数据传送到另一区域BUF2 中,要求用字符串处方法。(I)实验框图(II)实验代码DATAS SEGMENT BUF1 DB TBE123000000 COUNT EQU ($-BUF

11、1)DATAS ENDSEXTRA SEGMENT BUF2 DB COUNT DUP(?) ;定义了BUF1长度COUNT的字符串EXTRA ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATAS,ES:EXTRASTART: MOV AX,DATAS MOV DS,AX MOV AX,EXTRA MOV ES,AX LEA SI,BUF1 LEA DI,BUF2 MOV CX,COUNT ;设置CX的值 CLD ;设置DF=0,SI增加的方向进行串操作 REP MOVSB ;进行数据段DS到附加段ES的搬移 MOV AH,4CH INT 21HCODES EN

12、DS END START(III)实验结果字符串BUF1结果TBE123000000 见下图(IV)实验分析本题难度较小,只要一个重复前缀REP,再用MOVSB就可以实现“搬移”。4) 编写程序,在已知字符串中搜索特定字符#,若找到则AL返回0,找不到AL返回1,要求用字符串处理方法。(I)实验框图(II)实验代码DATAS SEGMENT BUF1 DB TBE123000000 COUNT EQU ($-BUF1)DATAS ENDSEXTRA SEGMENT CHAR DB #EXTRA ENDSCODES SEGMENT ASSUME CS:CODES,DS:DATAS,ES:DATASSTART: MOV AX,DATAS MOV DS,AX MOV ES,AX LEA DI,BUF1 MOV AL,# ;#放在AL中,准备使用SCASB指令 MOV CX,COUNT ;设置循环次数 CLD ;设置DF=0,正向操作 REPNE SCASB ;不相等时继续循环,相等时顺序执行下面指令 JZ FOUND ;若ZF=0,说明找到#,赋值AL=0 MOV AL,1 ;否则,没找到#,赋值AL=1 JMP EXIT FOUND: MOV AL,0 EXIT: MOV AH,4CH INT 21HCODES ENDS

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 解决方案

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号