汇编(三)段地址、偏移地址、内存单元、寄存器、CS、IP、代码段、debug、实验题

简介: 段地址、偏移地址、内存单元、寄存器、CS、IP、代码段、debug、实验题、汇编、汇编编程、win10怎么使用debug

**偏移地址:

偏移地址是指段内相对于段起始地址的偏移值,
例如一个存储器的大小是1KB,可以把它分为4段,第一段的地址范围就是0—255,第二段的地址范围就是256-511,依次类推。

段地址:

段地址就是每一段的首地址,第一段的段地址就是0,计算它们的物理地址只需要把段地址左移4位就可以了,再加上偏移地址就可以了

_2019_09_04_3_55_13
(H表示16进制)
_2019_09_04_9_32_40

段的概念:

错误认识:内存被划分成了一个一个的段,每个段有一个段地址
其实:
    内存并没有分段,段的划分来自于CPU,由于8086CPU用(段地址*16)+偏移地址=物理地址
    的方式给出内存单元的物理地址,使得我们可以用分段的方式来管理内存
以后在编程时可以根据需要,将若干个地址联系的内存单元看做一个段,用段地址*16定位段的起始地址(基础地址)
用偏移地址定位段中的内存单元
注意:
    1.段地址*16 必然是16的倍数,所以一个段的起始地址也一定是16的倍数
    2.偏移地址为16位,16位地址的寻址能力为64k  所以一个段的长度最大为64k

内存单元地址:

CPU访问内存单元时,必须向内存提供内存单元的物理地址
CPU可以用不同的段地址和偏移地址形成同一个物理地址
偏移地址16位,变化范围为0~FFFFH,仅用偏移地址最多可寻64k个内存单元
    比如段地址为10000H,用偏移地址寻址,CPU的寻址范围为:10000H~1FFFFH
在8086CPU中:
    存储单元的地址用两个元素来描述,即段地址和偏移地址
    
    数据在21F60H内存单元中 对于80806PC机的两种描述:
        1.数据存在内存2000:1F60单元中
        2.数存在内存的2000段中的1F60H单元中

段寄存器:

段寄存器就是提供段地址的
CS:代码段寄存器;
DS:数据段寄存器;
SS:堆栈段寄存器;
ES:扩展段寄存器;
IP:指令指针寄存器
当CPU要访问内存时,有这四个段寄存器提供内存单元的段地址
CS和ip是CPU中最关键的寄存器,他们指示了CPU当前要读取指令的地址

CPU工作原理:

1.从CS:IP指向内存单元读取指令,读取的指令进入指令缓冲器
2.IP=IP+所读取指令的长度, 从而指向下一条指令
3.执行指令,跳转到步骤1  重复过程
在加电或复位即CPU开始工作时 CS被设置为CS=FFFF,IP被设置为0000。
CPU从内存FFFF 0单元中读取执行指令
FFFF 0单元中的指令是开机后执行的第一条指令

CS和IP:

在任何时候 CPU将CS、IP中的内容当做指令的段地址和偏移地址,用他们合成指令的物理地址
到内存中读取指令码。执行

如果说内存中的段信息曾被CPU执行过的话,那么它所在的内存单元必然被CS:IP指向过

修改CS、IP的指令:

在CPU中,能够用指令读写部件只有寄存器。可以通过改变寄存器中的内容实现对CPU的控制
CPU从何处执行指令是由CS、IP中的内容决定的。可以通过改变CS、IP中的内容来控制CPU执行目标指令
如何改变:
    mov 传送指令
        如:mov ax, 123
        mov指令可以改变大部分寄存器的值,被称为传送指令
        mov指令不能设置CS、IP的值,8086提供了另外的指令来改变它们的值
    jmp 转移指令:
        同时修改CS、IP的内容:
        jmp 段地址:偏移地址
        如:
            jmp 2ae3:3
            jmp 3:0b16
        用指令中给出的段地址来修改CS, 偏移地址修改IP
仅修改IP的内容:
    jmp 某一合法寄存器
    如:
        jmp ax(类似于 mov IP,ax)
        jmp bx
    用寄存器中的值修改IP

代码段:

在编程是可以根据需要。将一组内存单元定义为一个段
可以将长度为n(n<=64kb)的一组代码 ,存在一组地址连续且起始地址为16的倍数
的内存单元中,这段内存是用来存放代码到的,从而定义了一个代码段

CPU只认 被CS:IP指向的内存单元 中的内容为指令
如何使得代码段中的指令被执行?
    将一段内存当做代码段,仅仅是我们在编程时的一种安排
    CPU并不会由于这种安排,就自动的将我们定义的代码段中的指令当做指令来执行 
    所以要将CS:IP指向所定义的代码段中的第一条指令的首地址

小结:

1.段地址在CPU的寄存器中存放,当CPU要访问内存时,由段寄存器提供内存单元的段地址
  CPU有4个段寄存器,其中CS来存放指令的段地址
2.CS存放指令的段地址,IP存放指令的偏移地址
  任意时刻,CPU将CS:IP指向的内容当做指令执行
3.CPU的工作过程:
    从CS:IP指向内存单元读取指令,读取的指令进入指令缓冲器
    IP指向下一条命令
    执行指令(调整到步骤1)重复这个过程
4.CPU提供转义指令来修改CS、IP的内容

debug:

老版本windows直接cmd  输入debug就可以进入
我的是win10  需要安装DOSbox软件
安装好DOSDbox后打开会有这样的界面
同时下载一个debug.exe  可以放在任意一个盘

在dosbox窗口输入:
    mount c d:\
    d:\
    debug:
进入debug模式(这里的d盘就是你放debug.exe的地方)

debug命令:

R命令:
    查看、改变 CPU寄存器的内容
D命令:
    查看内存中的内容
E命令:
    改写内存中的内容
U命令:
    将内存中的机器指令翻译成汇编指令
T命令:
    执行一条机器指令
A命令:
    以汇编指令的格式在内存中写入一条机器指令

课后题:

_2019_09_04_8_48_11
21_53_11__09_04_2019
20190904215956
20190904220244
20190904220457
20190904221349
20190904221518

第二题:

计算2的8次方
20190904222236

_2019_09_04_10_27_26

20190904223613
20190904224148

**

相关文章
|
3月前
|
缓存
内存学习(三):物理地址空间
内存学习(三):物理地址空间
62 0
|
3月前
|
存储 缓存 Unix
内存学习(一):物理地址空间内存概述
内存学习(一):物理地址空间内存概述
38 0
|
1月前
|
Python
Python中如何判断两个对象的内存地址是否一致?
Python中如何判断两个对象的内存地址是否一致?
17 0
|
1月前
|
存储 C语言
【C语言】深入理解取地址符&:与内存地址的联系
【C语言】深入理解取地址符&:与内存地址的联系
92 0
|
3月前
|
存储 缓存 安全
learn_C_deep_9 (汇编角度理解return的含义、const 的各种应用场景、volatile 的基本理解与实验证明)
learn_C_deep_9 (汇编角度理解return的含义、const 的各种应用场景、volatile 的基本理解与实验证明)
|
3月前
|
搜索推荐 Linux
内存学习(二):物理地址空间虚拟地址空间布局
内存学习(二):物理地址空间虚拟地址空间布局
77 0
|
3月前
|
编译器 存储 网络协议
【汇编】CS、IP寄存器与代码段,用汇编语言写的源程序,jmp指令
【汇编】CS、IP寄存器与代码段,用汇编语言写的源程序,jmp指令
【汇编】CS、IP寄存器与代码段,用汇编语言写的源程序,jmp指令
|
3月前
|
存储 程序员 数据处理
【汇编】mov和add指令、确定物理地址的方法、内存分段表示法
【汇编】mov和add指令、确定物理地址的方法、内存分段表示法
115 1
【汇编】mov和add指令、确定物理地址的方法、内存分段表示法
|
3月前
|
存储 程序员
【汇编】内存的读写与地址空间、寄存器及数据存储
【汇编】内存的读写与地址空间、寄存器及数据存储
143 1
【汇编】内存的读写与地址空间、寄存器及数据存储
|
4月前
|
索引
虚拟地址与物理内存地址是如何映射的
虚拟地址与物理内存地址是如何映射的