以下所有的总结基于我只学了前五章的前提下,可能会有错误
第一章:基础知识
- 在内存中把指令和数据区别开来: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是安全的空间
原文地址:https://www.cnblogs.com/rookiezjz/p/12688761.html
时间: 2024-10-10 17:17:20