1.大小写转换问题
小写字母的ASCII码值比大写字母的ASCII码值大20H
A 16进制 41 二进制01000001
a 16进制 61 二进制01100001
B 16进制 42 二进制01000010
b 16进制 62 二进制01100010
可以发现一个很特别的地方就是
小写字母第5位总是1,对应的大写字母第5位总是0
所以在进行字母转换的时候,比如要将小写字母a转换成大写字母,只要将
其a对应的二进制第5位设置为0
要将大写字母A转换成小写字母a 的时候只要将第5位的0设置为1
注意:参照上面的可以发现每个字符对应一个16进制,所以
可以这样定义字符串
db 'BaSic'
db 'iNfOrMaTiOn'
完整的程序如下
datasg segment
db 'BaSic'
db 'iNfOrMaTiOn'
datasg ends
codesg segment
start:
codesg ends
end start
用cmd运行了,但是在内存中没发现字符串被载入了,为啥呢?
对于下面的例子的理解
a[i]=a[i]&0xDF;
&按位与,就是将符号两边的都先化为二进制,再进行与运算
0xDF化为二进制为11011111,所以这个表达式是为了将a[i]转变成大写字母
b[i]=b[i]|0x20
|按位或,就是将符号两边都先化为二进制,再进行运算
0x20化为二进制为00100000
所以这个表达式就是为了将b[i]转变成小写字母
注意下面的问题:
请教8086汇编语言中ASSUME伪指令的作用!
1.书上说ASSUME语句可以使定义的段与段寄存器对应起来而在每一个ASSUME 语句后为什么还要通过如下的指令语句来给对应的段寄存器赋值?
ASSUME CS:CSEG, DS:DSEG
MOV AX, DSEG
MOV DS,AX
2.每个ASSUME语句后的段寄存器赋值为什么都不包括CS段的赋值语句?
先回答你的第一个问题,书上是你那样说的,至于你的第一个疑问是因为ASSUME伪指令只是让数据段寄存器DS与你的数据存储地址,代码段寄存器CS和你的代码段所存储的地址一一对应起来,但是如果你不人为把你的数据段存储地址DSEG传给DS的话,系统是无法获得DSEG的具体物理地址的。
对于第二疑问,因为CS:IP是指向CPU将执行的下一条语句,在将程序装载进主存时,系统就已经将CSEG的物理地址传给了CS,所以,对于CS不需要像DS那样人为传递。
之前的时候想实现将BaSic和iNfOrMaTiOn载入内存中,
assume cs:codesg,ds:datasg
datasg segment
db 'BaSic'
db 'iNfOrMaTiOn'
datasg ends
codesg segment
start:
codesg ends
end start
但是一直不行,最后找来找去才发现,除了assume指定cs和自定义的段codesg外还要将其地址关联起来
assume cs:codesg,ds:datasg
datasg segment
db 'BaSic'
db 'iNfOrMaTiOn'
datasg ends
codesg segment
start:
mov ax,datasg
mov ds,ax
codesg ends
最后功能实现了。
2.[bx+idata]
我们常用[bx]的方式来指明一个内存单元,还可以用一种更为灵活的方式来指定内存单元:[bx+idata]
转载于:https://my.oschina.net/liangzhenghui/blog/138125