汇编学习(一)

2018-11-24  本文已影响0人  鸡龙

在学习汇编语言中记录个人认为较重要的知识点

win10下debug安装和使用

debug安装:https://jingyan.baidu.com/article/9faa7231fd2775473c28cb26.html

debug使用命令:https://www.cnblogs.com/tiger2soft/p/5094917.html

8086给出物理地址的方法

物理地址=段地址*16+偏移地址

图中数据皆为十六进制表示

但CPU可以用不同的段地址和偏移地址形成同一个物理地址

例:

    物理地址:21F60H

    段地址+偏移地址组合可以有:(2000H:1F60H)(2100H:0F60H)(21F0H:0060H)

段寄存器CS和IP

CS和IP为8086中两个最关键的寄存器

物理地址可写成(CS:IP)对应(段地址:偏移地址)存储在CS和IP两个寄存器里

CS中内容为M,IP中内容为N,CPU将从内存M*16+N来读取一条指令并执行

段寄存器DS和[address]

DS是一个段寄存器,存放要访问数据的段地址。

比如我们要读取10000H单元的内容:

    mov bx,1000H

    mov ds,bx

    mov al,[0]

要注意,1000H不能直接送入ds,要经过一个寄存器来做中转,先放入一个一般寄存器bx再将bx中的内容送入ds。

[address]表示一个内存单元,里面的address表示内存单元的偏移地址,在我们使用这个偏移地址来定位一个具体内存单元时,会自动取ds中数据为内存单元的段地址。

和上面所提到一样,对于三种指令add,sub指令中,也不能直接对ds直接运算

三种指令在debug中对ds操作尝试

段寄存器SS和SP

当我们将10000H -- 1000FH这段内存当作栈使用时,SS存储栈顶的段地址,SP存储偏移地址。

任意时刻,SS:SP指向栈顶元素,下图为对栈操作指令push和pop功能的执行过程描述

push指令执行过程 pop指令执行过程

注意:push,pop等栈操作指令,修改的只是SP。也就是说,栈顶的变化范围最大为:0--FFFFH

上一篇 下一篇

猜你喜欢

热点阅读