汇编语言第4章王爽版程序设计(字符串)

上传人:ra****d 文档编号:252733348 上传时间:2024-11-19 格式:PPT 页数:40 大小:788KB
返回 下载 相关 举报
汇编语言第4章王爽版程序设计(字符串)_第1页
第1页 / 共40页
汇编语言第4章王爽版程序设计(字符串)_第2页
第2页 / 共40页
汇编语言第4章王爽版程序设计(字符串)_第3页
第3页 / 共40页
点击查看更多>>
资源描述
单击此处编辑母版文本样式,第二层,第三层,第四层,第五层,单击此处编辑母版标题样式,*,*,第4章汇编语言程序设计,一、概述,二、顺序程序设计,三、,DOS,系统功能调用,四、分支程序设计,五、循环程序设计,六、串处理类指令及程序设计,六、数据串处理指令,串传送指令MOVS ES:DIDS:SI,串读取指令LODS AL/AXDS:SI,3.串存储指令STOS ES:DIAL/AX,4.串比较指令CMPS DS:SIES:DI,5.串扫描指令SCAS AL/AXES:DI,6.重复前缀指令REP、REPZ、REPNZ,计算机更多的是要进行一些数据处理,主要的是字符串的处理。,熟悉串操作寻址的特点,串操作指令概括说明,为什么要用:数据传送类指令每次只能传送一个数据,假设要传送大批数据就需要重复编程通过循环来实现,这样就浪费了大量的时间和空间。为此8086提供了一组处理内存中连续存放数据的串指令,这就是串操作指令。,串操作指令是8086指令系统中比较独特的一类指令,采用比较特殊的数据串寻址方式,是可以直接实现存储区之间操作的指令。在操作内存连续区域的数据时,特别好用。,串操作指令的操作对象操作数是内存中连续存放的数据串String即在连续的内存区域中以字W为单位的字串,或是以字节B为单位的字节串,串寻址方式,名称:“S、“B、“W,格式:提供3种格式,常用的有2种。,隐含的都是双操作数指令,源操作数用存放器SI寻址,默认在数据段DS中,DS:SI,但允许段超越,目的操作数用存放器DI寻址,默认在附加段ES中,ES:DI,不允许段超越,每执行一次串操作指令,SI和DI值将自动修改:,1对于字节串或2对于字串,执行指令CLD指令后,DF=0,地址指针增1或2,执行指令STD指令后,DF=1,地址指针减1或2,串操作类指令,1.串传送指令*MOVS,2.串读取指令*LODS,3.串存储指令*STOS,4.串比较指令CMPS,5.串扫描指令SCAS,6.重复前缀指令REP*、REPZ、REPNZ,串传送MOVS,功能:将以SI为指针的源串中的一个字节或字存储单元中的数据传送至以DI为指针的目的地址中去,并自动修改指针,使之指向下一个字节或字存储单元。,即:DS:SIES:DI。,当DF=0时,SI和DI自动增量;当DF=1时,SI和DI自动减量。,MOVSB,;字节串传送:ES:DIDS:SI,;SISI1,DIDI1,演示,MOVSW,;字串传送:ES:DIDS:SI,;SISI2,DIDI2,演示,特殊性?,内存操作数之间直接传送,例1:字节串传送,mov si,offset source,mov di,offset destination,mov cx,100;cx传送次数,cld;置DF=0,地址增加,again:movsb;传送一个字节,dec cx;传送次数减1,jnz again,;判断传送次数cx是否为0,;不为0,那么到again位置执行指令,;否那么,结束,传送100个字节操作数的例子,例:字串传送,mov si,offset source,mov di,offset destination,mov cx,50;cx传送次数,cld;置DF=0,地址增加,again:movsw;传送一个字,dec cx;传送次数减1,jnz again,;判断传送次数cx是否为0,;不为0,那么到again位置执行指令,;否那么,结束,串读取LODS,LODSB,;字节串读取:ALDS:,SI,;SISI1,LODSW,;字串读取:AXDS:,SI,;SISI2,功能:将SI所指的源串中的一个字节或字存储单元中的数据取出来送入AL或AX中。,即:字节操作:SIAL,字操作:SIAX。,修改指针SI,使它指向串中的下一个元素。,当DF=0时,SI增量。当DF=1时,SI减量。,串存储STOS,STOSB,;字节串存储:ES:,DI,AL,;DIDI1,STOSW,;字串存储:ES:,DI,AX,;DIDI2,功能:将AL或AX中的数据送入DI所指的目的串中的字节或字存储单元中。,即:字节操作:ALDI,,字操作:AXDI。,修改指针DI,使之指向串中的下一个元素。,当DF=0时,DI增量;当DF=1时,DI减量。,例:串存储,mov ax,0,mov di,0,mov cx,1000h,cld,;DF=0,地址增加,again:,stosw,;传送一个字,loop again,;传送次数cx是否为0,stos指令应用:数据区初始化,结果是什么?,串比较CMPS,功能:将SI所指的源串中的一个字节或字存储单元中的数据与DI所指的目的串中的一个字节或字存储单元中的数据相减,并根据相减的结果设置标志,但结果并不保存。,即:SIDI。,修改串指针,使之指向串中的下一个元素。,当DF=0时,SI和DI增量。,当DF=1时,SI和DI减量。,CMPSB;字节串比较:DS:SIES:DI,;SISI1,DIDI1,CMPSW;字串比较:DS:SIES:DI,;SISI2,DIDI2,特殊?,例:字符串比较,mov si,offset string1,mov di,offset string2,mov cx,count,cld,again:cmpsb;比较两个字符,jnz unmat;有不同字符,转移,dec cx,jnz again;进行下一个字符比较,mov al,0;字符串相等,设置00h,jmp output;转向output,unmat:mov al,0ffh;设置ffh,output:mov result,al;输出结果标记,对string1和string2两个字符串,进行比较,假设串相同,在result单元中置0,否那么置1,Loop again,串扫描SCAS,功能:AL字节或AX字中的内容与DI所指的目的串中的一个字节或字存储单元中的数据相减,根据相减结果设置标志位,结果不保存。,即:,字节操作:ALDI,字操作:AXDI。,修改指针使之指向串中的下一个元素。,当DF=0时,DI增量。当DF=1时,DI减量。,SCASB,;字节串扫描:ALES:DI,;DIDI1,SCASW,;字串扫描:AXES:DI,;DIDI2,例:查找字符串,利用scas指令可以进行搜索。把要搜索的关键字放在AL或AX中,用以搜索内存的某一数据块或字符串中,有无此关键字,假设有,那么把搜索次数记下来假设次数为0,表示无要搜索的关键字,并且记录下存放关键字的地址。,程序一开始,当然要设置数据块的地址指针 scas指令要求设在DI中,要设立数据块的长度要求设在CX中,把关键字送入AL或AX中。利用Z标志以判断是否搜索到,以便分别处理。,scas指令应用,例3:查找字符串,mov di,offset string,mov al,20h;空格的ASCII码值,mov cx,count,cld,again:scasb;搜索,jz found;为0ZF=1,发现空格,dec cx;不是空格,jnz again;搜索下一个字符,.;不含空格,那么继续执行,found:.,重复前缀指令rep,串操作指令执行一次,仅对数据串中的一个字节或字进行操作。但是在串操作指令前,都可以加一个重复前缀,实现串操作的重复执行。重复次数隐含在CX存放器中,重复前缀3条指令:,REP、REPZ和REPNZ,REP重复前缀指令,REP前缀功能:当,CX0时,重复执行后面的,串指令,。可以理解为,每执行一次后面的串指令,CX减1,并回送CX,直到CX0,重复执行结束。,例,和,例,中,程序段的最后3条指令,可以分别替换为:,REP MOVSB 和 REP STOSW,格式:REP,串指令,说明:REP指令一般用在MOVS、STOS 指令前,重复串传送例5,mov si,offset source,mov di,offset destination,mov cx,100,;cx传送次数,cld,rep movsb,again:movsb;传送一个字节,dec cx;传送次数减1,jnz again;判断传送次数cx是否为0,;不为0ZF=0,那么转移again位置执行,;否那么,结束,重复串存储例6,mov al,0,mov di,0,mov cx,8000h,cld,rep stosb,again:stosb,;传送一个字,dec cx,;传送次数减1,jnz again,;判断传送次数cx是否为0,演示,REPZ重复前缀指令,REPZ/REPE前缀的功能:重复执行串指令的条件是:CX0,且字符相等ZF1。可以理解为:每执行一次串指令,CX减1回送CX,并判断ZF是否为0,只要CX0或ZF0,重复执行结束,格式:REPZ,串指令,说明:REPZ后面常跟CMPS串指令,用于字符串的比较。,REPNZ重复前缀指令,REPNZ/REPNE功能:重复执行后面串指令的条件是:CX0并且串不相等ZF0。可以理解为:每执行一次后面的串指令,CX减1,并判断ZF是否为1,只要CX0或ZF1,重复执行结束,格式:REPNZ,串指令,说明:,REPNZ,后面常跟SCAS串指令,用于搜索一个字符。,例7:比较字符串(对例的改进),mov si,offset string1,mov di,offset string2,mov cx,count,cld,repz cmpsb;重复比较两个字符,jnz unmat;字符串不等,转移,mov al,0;字符串相等,设置00h,jmp output;转向output,unmat:mov al,0ffh;设置ffh,output:mov result,al;输出结果标记,解释,重复比较的解释,指令repz cmpsb结束重复执行的情况,ZF0,即出现不相等的字符,CX0,即比较完所有字符:,这种情况下,如果ZF0,说明最后一个字符不等;而ZF1表示所有字符比较后都相等,也就是两个字符串相同,所以,重复比较结束后,jnz unmat指令的条件成立ZF0,字符串不相等,例8:查找字符串,mov di,offset string,mov al,20h,mov cx,count,cld,repnz scasb;搜索,jz found;ZF=1,发现空格,.;不含空格,那么继续执行,found:.,Scasb指令的应用,使用重复前缀指令REP、REPZ、REPNZ前,需要初始化以下内容:,源串地址指针SI,目的串地址指针DI,方向标志DF,循环计数器CX,重复前缀指令小结,data segment,s1 db 100 dup(66h),s2 db 100 dup(00),data ends,code segment,assume cs:code,ds:data,es:data,start:,mov ax,data,mov ds,ax,mov es,ax,lea si,s1,lea di,s2,mov cx,100,cld,rep movsb,mov ah,4ch,int 21h,code ends,end start,例4,.13字节数据串传送的例子。,用带,重复前缀,的串操作指令实现,DATA SEGMENT,block dw count ;block的元素个数,Dw,1234h,4321h,0abcdh,0b645h,8367h,3456h,6845h,0fffeh,count=($-block)/2-1,buf1 dw 0;正数的个数,dw count dup(0);存放正数,buf2 dw 0;负数的个数,dw count dup(0);存放负数,DATA ENDS,code segment,assume cs:code,ds:data,es:data,start:,mov ax,data,mov ds,ax,mov es,ax,例4,.14,串指令LODS和STOS的应用例子,。在block数据区有一组字数据,要求将正数和负数分开存放,并统计个数,lea si,bl
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 商业管理 > 商业计划


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!