文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

汇编语言功能字符串大小写转换实现实例详解

2024-04-02 19:55

关注

问题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

以上就是汇编语言功能大小写转换实现实例详解的详细内容,更多关于汇编语言功能大小写转换的资料请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯