以下所有的总结基于我只学了前五章的前提下,可能会有错误
第一章:基础知识
-
在内存中把指令和数据区别开来:cs:ip指向的内存中的”数据“就是cpu认为的指令。
-
一个储存单元:2个16进制数字,8位,1个字节
-
cpu将系统中各类内存器看作一个逻辑内存器
第二章:寄存器
-
8086cpu的所有寄存器都是16位的
-
8086cpu中 1个字 = 2个字节
-
xx位cpu指的是:运算器一次处理的数据位数,寄存器位数,计算器与运算器之间通路的位数
-
8086有20位地址总线,用两个寄存器(段地址,偏移地址)来表示内存地址,具体计算方法是(段地址*16+偏移地址)就是内存地址
-
段地址的起始地址只能是16的倍数(段地址*16,偏移量为0)
-
cs:ip指向下一个要执行指令的地址
-
修改cs:ip : jmp cs:ip
-
debug用法
- r : 查看所有寄存器状态
- r ax(cs,ip...):修改ax的值
- d ds:bx ax:查看ds:bx到ds:ax的值
- e ds:ax 修改ds:ax的值
- u cs:ip :查看汇编指令(如果可以反汇编成汇编指令的话)
- a ds:ax :写汇编指令
第三章:寄存器(内存访问)
-
一个字的地址是这个字的低8位所在的内存地址
-
访问内存数据 ds:[bx]
- debug中可以[idata]访问,写汇编文本文源文件的时候不可以
- 源文件:ds:[idata] 或者 [寄存器]
-
add,sub 不可以操作段寄存器
-
ss:sp指向栈顶
第四章:第一个程序
assume cs: code
code segment
...
mov ax,4c00h
int 21h
code ends
end
-
loop s:(cx) = (cx)-1, 如果cx不为0,ip跳到s的位置,否则往下执行
-
0:200-0:2ff是安全的空间
第五章:[BX]和loop
-
loop 语法
s: code... code... loop s ;每进行一次loop,cx减一,直到为0,跳出循环
-
在源代码中,[idata]会被解释为idata, 而不是 ds:[idata], 所以源代码中需要显式的写 ds:[idata], 或者[bx]