问题1:将data段中的第一个字符串转换成大写,第二个字符串转换成小写
分析:
如何转换成大小写
如果利用ASCII码进行转换的话,需要判断该字符是大写还是小写,汇编语言实现太过困难,可以对字符串的二进制进行分析。
在ASCII码中,大写字母的第五位为0,小写字母的第五位为1,可以对位取反进行大小写转换
assume cs:code,ds:data
data segment
db 'BaSiC'
db 'InfoMaTion'
data ends
;------------------------------------
;做法一
code segment
start: mov ax,data
mov ds,ax
mov bx,0 ;设置ds:bx指向数据段
mov cx,5 ;对于第一个字符串进行循环转换
s: mov al,ds:[bx]
and al,11011111B ;将字符的第五位转换成0,转换成大写字母
mov ds:[bx],al
inc bx
loop s
mov bx,5 ;指向第二个字符串
mov cx,11
s0: mov al,ds:[bx]
or al,00100000B ;将字符的第五位转换成1,转换成小写字母
mov ds:[bx],al
inc bx
loop s
mov ax,4c00h
int 21h
code ends
;------------------------------------
;做法二,改进版:利用bx+idata实现代码的简化
code segment
start: mov ax,data
mov ds,ax
mov bx,0
mov cx,5
s: mov al,ds:[bx]
and al,11011111b
mov ds:[bx],al
mov al,ds:[bx+5]
or al,00100000b
mov ds:[bx+5],al
inc bx
loop s
code ends
;------------------------------------
end start
问题2:将data段中每个单词的头一个字母改成大写字母
分析: 如何实现循环
该段数据是结构化的数据,则可以看做成一个二维数组,用一个变量定位行,用一个常量定义第一个字母
assume cs:code,ds:data
data segment
db '1. file '
db '2. edit '
db '3. search '
data ends
code segment
start: mov ax,data
mov ds,ax
mov bx,0 ;ds:bx指定数据段,同时bx作为定义行的变量
mov cx,3
s: mov al,ds:[bx+3] ;3作为常量,定义第一个字母
and al,11011111b
mov ds:[bx+3],al
add bx,16
loop s
mov ax,4c00h
int 21h
code ends
end
问题3:将data段中每个单词改为大写字母
分析: 1、对于这种结构化的数据,不仅需要一个变量定义行,同时也需要一个变量定义列
assume cs:code,ds:data,ss:stack
data segment
db 'ibm '
db 'dec '
db 'vax '
data ends
;--------------------------------------------
;做法一
code segment
start: mov ax,data
mov ds,ax
mov bx,0
mov cx,3
s0: mov dx,cx ;同时使用同一个变量进行循环,需要对外层循环的值保存
mov si,0
mov cx,3 ;cx设置成内层循环的次数
s: mov al,ds:[bx+si]
and al,11011111b
mov ds:[bx+si],al
inc si
loop s
add bx,16
mov cx,dx ;用dx中存放的外层循环恢复外层循环的计数器
loop s0
mov ax,4c00h
int 21h
code ends
;--------------------------------------------
;做法二,利用栈保存外层循环的值
stack segment
dw 8 dup(0) ;利用栈段保存cx的值
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,16 ;ss:sp指向栈段
mov ax,data
mov ds,ax
mov bx,0 ;ds:bx指向数据段
mov cx,3
s0: push cx
mov si,0
mov cx,3
s: mov al,ds:[bx+si]
and al,11011111b
mov ds:[bx+si],al
inc si
loop s
add bx,16
pop cx
loop s0
mov ax,4c00h
int 21h
code ends
;--------------------------------------------
end start
问题4:将data段中每个单词的前4个字母改为大写字母
分析 如何定位每个字符串的内容
采用bx+si+idata来进行首字母的定位
assume cs:code,ds:data,ss:stack
data segment
db '1. display '
db '2. brows '
db '3. replace '
data ends
stack segment
dw 8 dup(0)
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,16
mov ax,data
mov ds,ax
mov bx,0
mov cx 3 ;设置外层循环只有3行
s0: push cx
mov si,0
mov cx,4 ;设置内层循环只需4次
s: mov al,ds:[bx+si+3] ;设置需要改变的第一个字母
and al,11011111b
mov ds:[bx+si+3],al
inc si
loop s
add bx,16
pop cx
loop s0
mov ax,4c00h
int 21h
code ends
end start
问题5:设计一个子程序,将一个全是字母的字符串转化成大写
分析: 子程序的设计需要注意两个问题:字符串的内容和长度
字符串的内容不可能全部放在子程序中,可以考虑在子程序中放入字符串的首地址,利用循环遍历字符串,循环的次数就是字符串的长度
assume cs:code,ds:data
data segment
db 'conversation'
data ends
code segment
start: mov ax,data
mov ds,ax
mov si,0 ;ds:si指向字符串所在空间的首地址
mov cx,12 ;cx存放字符串的长度
call capital
mov ax,4c00h
int 21h
capital: and byte ptr ds:[si],11011111b
inc si
loop capital
ret
code ends
end start
问题6:设计一个子程序,将一个全是字母,以0结尾的字符串,转化成大写
分析:
1、要处理以0结尾的字符串,需要识别结尾的0
采用jcxz进行判断最后的字符是否是0
2、循环的次数无法知道
所以不能用loop,只能使用jmp跳到循环开始处
assume cs:code,ds:data
data segment
db 'conversation',0
data ends
code segment
start: mov ax,data
mov ds,ax
mov si,0 ;ds:si指向数据段的开始处
call capital
mov ax,4c00h
int 21h
capital: mov cl,ds:[si]
mov ch,0
jcxz ok ;如果字符串为0,则会跳出循环
and byte ptr ds:[si],11011111b
inc si
jmp short capital ;跳转实现循环
ok: ret ;结束循环
code ends
end start
复杂一点的对结构化数据的版本
assume cs:code,ds:data,ss:stack
data segment
db 'word',0
db 'unix',0
db 'wind',0
data ends
stack segment
db 8 dup(0)
stack ends
code segment
start: mov ax,data
mov ds,ax
mov bx,0
mov cx,3 ;外循环实现
s: mov si,bx
call capital
add bx,5 ;内循环的实现
loop s
mov ax,4c00h
int 21h
capital: push cx
push si
change: mov cl,ds:[si]
mov ch,0
jcxz ok
and byte ptr ds:[si],11011111b
inc si
jmp short change
ok: pop si
pop cx
ret
code ends
end
以上就是汇编语言功能大小写转换实现实例详解的详细内容,更多关于汇编语言功能大小写转换的资料请关注编程网其它相关文章!