第七章知识汇总

第7章   更灵活地定义内存地址的方法

7.1   and和or指令

(1)and指令:逻辑与指令,按位进行与运算(相当于将某一位或几位的值变为0)

例如:mov al,01100011B

   and al,00111011B

执行后  al=00100011B

(2)or指令:逻辑或指令,按位进行或运算(相当于将某一位或几位的值变为1)

例如:mov al,01100011B

   or   al,00111011B

执行后:al=01111011B

7.2   关于ASCII码

我们的操作————转换为ASCII码—————写入指定内存空间————转换成我们想要的效果

7.3以字符形式给出的数据

在汇编程序中,我们用'......'的方式来指明数据是以字符形式给出的

我们以下面的程序为例:

assume cs:code,ds:data

data segment

  db 'unIX'

  db 'foRX'

data ends

code segment

start:mov al,'a'

  mov bl,'b'

  mov ax,4c00h

  int 21h

codesg ends

end start

这里对上述代码做几点解释:

(1)db 'foRK'  相当于“db 75H,6EH,49H,58H”

  PS:和  dw做一下比较

(2)mov ax,'a'相当于mov ax,61H

在debug中可以用r命令先分析一下data的地址,然后可以用d命令来查看段中的16进制的数码和对应的ASCII码

 7.4大小写转换的问题

我们考虑这样一个问题,在codesg中填写代码。将datasg中的一个字符串转换为大写,第二个字符串转换为小写

小写字母的ASCII码比其对应的大写字母要大20H

那么转换为大写的话,只要将小写字母对应的数值减去20H就行了;准换为小写的话就反过来

可是我们又面临一个问题:如何判断字母的大小写?

我们现在没有学习到可以判断的指令,但是现阶段又要求我们解决此类问题。依照书中思想,我们不妨试试看绕过判断来解决问题

这就用到了我们前面预先学习的and和or指令

我们发现  大写与小写字母的ASCII码的二进制形式,差别只在第五位,而大写字母的第五位为0,小写字母的第五位为1。因此问题只要合理运用and和or指令就能解决

下面给出解决问题的程序:
assume cs:codesg,ds:datasg

datasg segment

  db 'BaSiC'

  db 'iNfOrMaTiOn'

datasg ends

codesg segment

start:mov ax,datasg

  mov ds,ax

  mov bx,0

  mov cx,0

 s:mov al,[bx]

  and al,11011111B

  mov [bx],al

  inc bx

  loop s

;转换成小写一次类推

  mov ax 4c00h

  int 21h

codesg ends

end start

7.5    [bx+idata]

[bx+idata]表示什么?表示一个内存单元,他的偏移地址为(bx)+idata(bx中的数值加上idata),段地址在ds中

[bx+idata]还可以写成其他形式:[200+bx]

              200[bx]

               [bx].200

7.6    用[bx+idata]的方式进行数组的处理

将与数组一起理解时,要注意一点:idata和c语言中的未知数不同,在数列中,C语言中的未知数是来确定同一数组中的不同元素的,而idata则是用来定义另一个或多个数组的

7.7    SI和DI

SI和DI是8086CPU中和bx功能相近的寄存器,不同的是SI和DI不能分为两个8位寄存器来使用

7.8  [bx+si]和[bx+di]

可以用[bx+idata]来帮助理解,

另外 [bx+si]也可以表示为[bx][si]

7.9 [bx+si+idata]和[bx+di+idata]

其他的表示方法:[bx+200+si]

        [200+bx+si]

        200[bx][si]

        [bx].200[si]

        [bx][si].200

7.10  不同寻址方式的灵活应用

定位内存地址的方式,我们称之为寻址方式

有下列几点发现:

(1)[idata]用一个常量来表示地址,可用于直接定位一个内存单元

(2)[bx]用一个变量来表示内存地址,可用于间接定位一个内存单元

(3)[200+bx]用一个变量和常量来表示地址,可在一个起始地址的基础上用变量间接定位一个内存单元

(4)[bx+si]用两个变量表示地址

(5)[bx+200+si]用两个变量和一个常量表示地址。

P152 从这需要认真看到本章实验

猜你喜欢

转载自www.cnblogs.com/1198264220pl/p/11982pl6422010.html