第五章 [bx]和loop指令
1,( )表示一个寄存器或一个内存单元中的内容。( )中的元素可以有三种类型:寄存器名,段寄存器名,内存单元的物理地址。
2,(x)所表示的数据类型有两种:字节与字。
3,inc bx为bx中的内容+1
4,cpu执行loop指令时
1)(cx)=(cx)-1
2)判断cx的值,不为零则转至标号处执行程序,若为零则向下执行。即用cx的值控制执行次数。
第六章 包含多个段的程序
1,dw:define word。因为dw定义的数据位于代码段的最开始,所以偏移地址位0,这八个数据就在代码段的偏移0、2、4、6、8、A、C、E处
2,在8086cpu中一个短的容量不能大于64kb
第七章 更灵活的定位内存地址的方法
1,and指令:遇零则零;or指令:遇一则一
2,在汇编程序中,用’...’的方式表明数据是字符的形式给出的,编译器将其转化为相对应的ASCⅡ码。小写字母的ASCⅡ码比大写字母的ASCⅡ码值大20H。
3,一个字母不管他原来是大写还是小写,将他的第五位0必变为大写字母,将他的第五位1必为小写字母
4,Si,di是8086cpu中和bx功能详尽的寄存器,si和di不能够分成两个8位寄存器使用。
5,寻访方式
1)[idata]用一个常量来表示地址,可用于直接定位一个内存单元
2)[bx]用一个变量来表示内存地址,可用于间接定位一个内存单元
3)[bx+idata]用一个变量和常量表示地址,可在一个起始地址的基础上用变量间接定位一个内存单元
4)[bx+si]用两个变量表示地址
5)[bx+si+idata]可用两个变量和一个常量表示地址
6,一般来说,在暂存数据时,都会用到栈
第八章 数据处理的两个基本问题
1,bx,si,di的默认偏移地址为ds,bp的默认偏移地址为ss
2,处理数据的长度
1)通过寄存器名指明要处理的数据的尺寸
2)在没有寄存器名存在的情况下,用操作符x ptr指明内存单元的长度,x在汇编指令中可以为word或byte
3)其他方法
3,div:如果除数为8位,则al储存除法操作的商,ah储存除法操作的余数;如果除数为16位,如果除数时16位,则ax储存器储存除法操作的商,dx存储除法操作的余数
4,用[bx+idata+si]的方式访问结构体中的数据,用bx定位整个结构体,用idata定位结构体中的某一项数据项,用si定位数组中的每个元素
5,Dup使用格式
1)db重复的次数dup(重复的字节型数据)
2)dw重复的次数dup(重复的字型数据)
3)dd重复的次数dup(重复的双字型数据)