第七章 更灵活的定位内存地址的方法

Posted yangruzhang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了第七章 更灵活的定位内存地址的方法相关的知识,希望对你有一定的参考价值。

一、and和or指令

and指令:逻辑与指令,按位进行与运算。(仅在1与1时结果中为1)

eg:mov al,01100011B

        and al,00111011B

结果:al=00100011B

作用:通过该指令可以将操作对象的相应位设为0,其他位不变。

or指令:逻辑或指令,按位进行或运算。(仅在0或0时为0)

eg:mov  al,01100011B

        or   al,00111011B

结果:al=01111011B

作用:通过该指令可以将操作对象的相应位设为1,其他位不变。

 注意:(1)and和or指令的格式需要参照add指令。

            (2)在debug中,默认十六进制,不支持二进制写法。

            (3)在.asm格式的完整汇编源程序文件中,默认十进制;也支持二进制、十六进制写法。(加B->二进制,加H->16进制)

二、关于ASCII码(略)

三、以字符形式给出的数据

用‘......‘的形式指明数据是以字符的形式给出的,编译器将把它们转化为相对应的ASCII码。

eg:“db ‘unIX‘ ”相当于“db 75H,65H,49H,58H”,“u”、“n”、“I”、“X”的ASCII码分别为75H、6EH、49H、58H。

四、大小写和数字字符与数字间的转化问题

规律ASCII码:大写字母+20H=小写字母

技术分享图片

规律ASCII码:数字字符-30H=数字

技术分享图片

注意:在汇编源程序中:既可以使用诸如‘a‘这样的字符写法,也可以使用ASCⅡ码形式的写法。 在debug中: a命令中不支持诸如‘a‘这样的写法 e命令中支持诸如‘a‘这样的写法,也支持ASCⅡ码形式的写法。

 五、其他灵活的地址表示方式

①用[bx + idata]表示表示内存单元。idata表示常数。

②用[si]表示表示内存单元。用[si + idata]表示表示内存单元。idata表示常量。

③用[di]表示表示内存单元。用[di + idata]表示表示内存单元。idata表示常量。

④用[bx+di], [bx+si]表示表示内存单元。 用[bx+di+idata], [bx+si+idata]表示表示内存单元。

写法:

技术分享图片

 

以上是关于第七章 更灵活的定位内存地址的方法的主要内容,如果未能解决你的问题,请参考以下文章

第七章 更灵活的定位内存地址的方法 知识梳理

[汇编]《汇编语言》第7章 更灵活的定位内存地址的方法

汇编语言——更灵活的定位内存地址的方法

《汇编语言》总结04 —— 更灵活的定位内存地址的方法

[汇编语言]实验:应用更灵活的寻址方式来定位内存地址

第七章——Windows内核基础-内核理论基础(内存空间布局,Windows与内核启动过程)