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

之前我们使用[0] [bx]

1、and指令

           mov al,01100011B   先将01100011B这8位数据放到al寄存器中

           and al,00111011B     然后按位与

执行后:al = 00100011B

2、and指令可以将操作对象的相应为设置为0

将al的第6位设置为0: and al,101111111B

3、or或运算

mov al,01100011B

or al,00111011B

执行后: al = 01111011B

4、or指令可以将操作对象的相应为设置为1

将al的第6位设置为1: or al,010000000B

5、ASCII码

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

db和dw的区别一个是字节一个是字型数据,我们的ASCII码只需要8位就可以存储了所以用db

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

mov al,'a'就相当于把a的ASCII给了al

对于ASCII码的大小写转换问题

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

区别在于第6位是0还是1

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

6、[bx + idate]

mov ax,[bx+200]

mov ax,200[bx]

mov ax,[bx].200

三种写法是一样的(ax) = ((ds)*16+(bx)+200)//段地址加上偏移地bx中的数值 + 200

下面这种方法可以把不同偏移的一起处理【bx + 5】

有100个数据我们就可以定义100个开头,bx都是一样的指向下一个

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

直接写

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

对其优化就可以一个循环

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

7、SI DI

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