通用的做法是把小写字母减掉20H就变成了大写,今天学到了一个小trick,挺好玩的:
;一个小小的程序-_-
assume cs:codesg,ds:datasg
datasg segment
db 'i love you'
datasg ends
codesg segment
start:mov ax,datasg;注意:不能直接把datasg送到ds,8086不支持数据直接送到段寄存器
;所以这里用ax来中转
mov ds,ax;ds指向数据段
mov bx,0;bx指向第一个字符
mov cx,10;循环次数
s:mov al,[bx]
and al,0dfh;and 11011111b,将ascii码第5位置0就变成了大写
mov [bx],al
inc bx;//指向下一个
loop s
mov ax,4c00h
int 21h
codesg ends
end start
启动虚拟机,用masm编译链接得到exe后,进入debug下调试:
r查看寄存器内容,在我的机器上显示ds的值是1590,这意味着代码其实是从15a0开始的(加了10h),使用d 1590:0看一下内存里的数据,能够观察到i love you(小写)。然后用t单步调试,做了一会儿再看看15a0:0这个的地方,已经变掉了:
类似地,如果是把大写变小写就把第5位改成1(or al,00100000b),位运算真是有趣啊~