x86汇编学习(MASM学习x86汇编语言2寄存器)(1)

一、一些基本概念二、8086的寄存器

寄存器是CPU内部高速存取数据的地方,比缓存更接近CPU的运算器。8086是16位cpu(字长16位):

这些寄存器分三种:

1. 通用寄存器

8086有14个寄存器:AX BX CX DX SI DI SP BP IP CS SS DS ES PSW。

2. 段寄存器

CPU读取指令的寻址=CS*16 IP,即从CS:IP处执行指令。读取指令后,IP值会自动增加指向下一条指令。

一段内存是放代码、数据还是栈,取决非于这几个段寄存器的设置。

3. 标志寄存器PSW

x86汇编学习(MASM学习x86汇编语言2寄存器)(2)

三、常用的汇编指令

x86汇编学习(MASM学习x86汇编语言2寄存器)(3)

四、一些汇编伪指令

汇编指令是CPU认识的对应2进制的指令,而伪指令是给编译器看的。

1. 段定义 segment

段名 segment ... 段名 ends 123

2. 汇编结束

end 1

3. 假设 assume

assume cs:codesg ; 假设代码寄存器和下面定义的codesg相关联 codesg segment ... codesg ends end

4. 寻址方式五、使用DosBox和Debug工具

64位操作系统无法直接使用Debug.exe工具了,需要安装一个DosBox,然后进行下面操作:

  1. 挂载本地磁盘,命令mount c: 本地文件夹
  2. 把debug.exe masm.exe和要调试的程序放到本地文件夹
  3. 然后就可以使用debug命令了。

常用的debug命令:

  1. R :查看更改cpu寄存器内容
  2. D:查看内存中内容
  3. E:改写内存中内容
  4. U:将内存中机器指令翻译成汇编指令
  5. T:执行一条机器指令
  6. A:以汇编格式在内存中写入一条指令
一段代码示例(1) 新建一个1.asm文件:

code segment assume cs:code s:mov ax,0025h mov cl,2 shl ax,cl mov ax,4ch int 21h code ends end s

(2) 启动DosBox挂载本地磁盘

mount c: d:/Documents/asm

x86汇编学习(MASM学习x86汇编语言2寄存器)(4)

(3) 编译

# 提示输入内容可以一直回车 c: masm 1.asm link 1.obj

这时生成1.exe

(4) debug加载

c: debug 1.exe

(5) 使用指令查看

u

x86汇编学习(MASM学习x86汇编语言2寄存器)(5)

六、使用OllyDbg反汇编和跟踪程序

OllyDbg通常称作OD,是反汇编工作的常用工具。下载地址:www.ollydbg.de

启动后,可以加载上篇编译的Hello.exe程序:

x86汇编学习(MASM学习x86汇编语言2寄存器)(6)

可以看出编译器编译、链接后的代码与手写的汇编代码还是存在很大的差异。

这里可以设置断点、跟踪程序,右侧还有一些寄存器的值可以查看。

,