美文网首页
汇编学习(一)

汇编学习(一)

作者: 鸡龙 | 来源:发表于2018-11-24 12:25 被阅读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

相关文章

  • ARM64汇编学习笔记一(初始汇编)

    ARM64汇编学习笔记一(初始汇编)

  • IOS 逆向开发(二十一) 汇编-基础

    @[TOC](IOS 逆向开发(二十一) 汇编-基础) 1. 汇编简介 为啥要需要学习汇编? 大学都学习过汇编语言...

  • 汇编学习(一)

    最近在学习逆向这一块儿,学习后按照自己的理解整理一下,以便加深理解。有不对的地方 后面慢慢改正。 1 汇编语言介绍...

  • 汇编学习(一)

    在学习汇编语言中记录个人认为较重要的知识点 win10下debug安装和使用 debug安装:https://ji...

  • 汇编学习(一)

    001--初识汇编 我们在学习逆向开发之前,我们要了解一个基本的逆向原理.首先我们是逆向iOS系统上面的APP.那...

  • 汇编

    汇编学习

  • 51汇编学习

    51汇编学习 参考 汇编教程http://www.51hei.com/mcuteach/252.html 汇编指令...

  • 2.1汇编的学习环境搭建

    2.1汇编的学习环境搭建 2.1.1【我们为什么要学习汇编】 汇编的作用有很多,这里我们更偏终于对高级语言的理解,...

  • 学习汇编 -- 汇编基础

    ###机器语言计算机语言大致分三类:计算机语言、汇编语言、高级语言。 计算机语言:由0和1组成的机器指令 汇编语言...

  • VS2019查看汇编代码

    必须有至少一个断点:调试 --> 窗口 --> 反汇编 C 语言、汇编同步学习

网友评论

      本文标题:汇编学习(一)

      本文链接:https://www.haomeiwen.com/subject/kkcsqqtx.html