【汇编语言】寄存器(CPU工作原理)(四)—— “段地址x16 + 偏移地址 = 物理地址”的本质含义以及段的概念和小结

news/2024/10/8 14:40:55 标签: java, android, 机器学习, 汇编语言

在这里插入图片描述

文章目录

  • 前言
  • 1. "段地址x16 + 偏移地址 = 物理地址"的本质含义
  • 2. 段的概念
  • 3. 内存单元地址小结
  • 结语

前言

📌

汇编语言是很多相关课程(如数据结构、操作系统、微机原理)的重要基础。但仅仅从课程的角度出发就太片面了,其实学习汇编语言可以深入理解计算机底层工作原理,提升代码效率,尤其在嵌入式系统和性能优化方面有重要作用。此外,它在逆向工程和安全领域不可或缺,帮助分析软件运行机制并增强漏洞修复能力。

本专栏的汇编语言学习章节主要是依据王爽老师的《汇编语言》来写的,和书中一样为了使学习的过程容易展开,我们采用以8086CPU为中央处理器的PC机来进行学习。

文章主要内容:"段地址x16 + 偏移地址 = 物理地址"的本质含义以及段的概念

1. "段地址x16 + 偏移地址 = 物理地址"的本质含义

了解其本质含义有助于我们未来更加灵活地分析解决问题

“段地址x16+偏移地址=物理地址”的本质含义是:CPU在访问内存时,用一个基础地址(段地址x16)和一个相对于基础地址的偏移地址相加,给出内存单元的物理地址。

更一般地说,8086CPU的这种寻址功能是“基础地址+偏移地址=物理地址”寻址模式的一种具体实现方案。8086CPU中,段地址x16可看作是基础地址。

下面,我们用两个与CPU无关的例子做进一步的比喻说明。

🎈第一个比喻说明“基础地址+偏移地址=物理地址”的思想:

比如说,学校、体育馆、图书馆同在一条笔直的单行路上(参考下图),学校位于路的起点(从路的起点到学校距离是0米)。

在这里插入图片描述

你要去图书馆,问我那里的地址,我可以用两种方式告诉你图书馆的地址:

(1)从学校走 2826m 到图书馆。这 2826m可以认为是图书馆的物理地址。

(2)从学校走 2000m到体育馆,从体育馆再走826m 到图书馆。第一个距离 2000m,是相对于起点的基础地址,第二个距离826m是相对于基础地址的偏移地址(以基础地址为起点的地址)。

第(1)种方式是直接给出物理地址 2826m,而第(2)种方式是用基础地址和偏移地址相加来得到物理地址的。




🎈第二个比喻进一步说明“段地址x16+偏移地址=物理地址”的思想。

我们为上面的例子加一些限制条件,比如,只能通过纸条来互相通信,你问我图书馆的地址我只能将它写在纸上告诉你。显然,我必须有一张可以容纳4位数据的纸条,才能写下 2826 这个数据。

在这里插入图片描述

可不巧的是,我没有能容纳4位数据的纸条,仅有两张可以容纳3位数据的纸条。这样我只能以下面这种方式告诉你 2826 这个数据。

在这里插入图片描述

在第一张纸上写上 200(段地址),在第二张纸上写上826(偏移地址)。假设我们事前对这种情况又有过相关的约定:你得到这两张纸后,做这样的运算:200(段地址)x10+826(偏移地址)=2826(物理地址)。

8086CPU就是这样一个只能提供两张3位数据纸条的CPU。

2. 段的概念

“段地址”这个名称中包含着“段”的概念。这种说法可能对一些学习者产生了误导,使人误以为内存被划分成了一个一个的段,每一个段有一个段地址。如果我们在一开始形成了这种认识,将影响以后对汇编语言的深入理解和灵活应用。

其实,内存并没有分段,段的划分来自于CPU,由于8086CPU用“基础地址(段地址x16)+偏移地址=物理地址”的方式给出内存单元的物理地址,使得我们可以用分段的方式来管理内存。如下图所示,我们可以认为:

  • 地址10000H~100FFH的内存单元组成一个段,该段的起始地址(基础地址)为10000H,段地址为1000H,大小为100H。(大小指的是这个段的长度
  • 也可以认为地址10000H1007FH、10080H100FFH的内存单元组成两个段,它们的起始地址(基础地址)为:10000H和10080H,段地址为:1000H和1008H,大小都为80H。(大小指的是这个段的长度

在这里插入图片描述

以后,在编程时可以根据需要,将若干地址连续的内存单元看作一个段,用段地址x16定位段的起始地址(基础地址),用偏移地址定位段中的内存单元。

有两点需要注意

  1. 段地址x16必然是16的倍数,所以一个段的起始地址也一定是16的倍数
  2. 偏移地址为16位,16位地址的寻址能力为64KB,所以一个段的长度最大为64KB。(因为一个段是通过“基础地址(段地址x16)+偏移地址=物理地址”来寻找地址的,所以当一个段的起始地址由段地址确定后,大小也就是范围就会由偏移地址的寻址能力决定)

3. 内存单元地址小结

CPU访问内存单元时,必须向内存提供内存单元的物理地址。8086CPU在内部用段地址和偏移地址移位相加的方法形成最终的物理地址。

那么现在请你思考下面的两个问题:

(1)观察下面的地址,你有什么发现?

在这里插入图片描述

✍结论:CPU可以用不同的段地址和偏移地址形成同一个物理地址。

比如 CPU 要访问 21F60H 单元,则它给出的段地址 SA 和偏移地址 EA 满足 SAX16+EA=21F60H 即可。




(2)如果给定一个段地址,仅通过变化偏移地址来进行寻址,最多可以定位多少内存单元?

✍结论:偏移地址16位,变化范围为0~FFFFH,仅用偏移地址来寻址最多可寻64K个内存单元。

比如:给定段地址1000H,用偏移地址寻址,CPU的寻址范围为:10000H~1FFFFH。




补充:

在8086PC机中,存储单元的地址用两个元素来描述,即段地址和偏移地址
“数据在 21F60H内存单元中。”这句话对于8086PC机一般不这样讲,取而代之的是两种类似的说法:

  1. 数据存在内存2000:1F60单元中

  2. 数据存在内存的2000H段中的1F60H单元中

这两种描述都表示“数据在内存21F60H单元中”

可以根据需要,将地址连续、起始地址为16的倍数的一组内存单元定义为一个段。

结语

今天的分享到这里就结束啦!如果觉得文章还不错的话,可以三连支持一下。

也可以点点关注,避免以后找不到我哦!

Crossoads主页还有很多有趣的文章,欢迎小伙伴们前去点评,您的支持就是作者前进的动力!

在这里插入图片描述


http://www.niftyadmin.cn/n/5694307.html

相关文章

《数据结构》学习系列——树(上)

系列文章目录 目录 树的基本概念树的定义树的特点树的相关术语度层数高度路径二叉树定义特点定理满二叉树定义特点完全二叉树定义特点二叉树的存储结构顺序存储结点结构优点缺点 链式存储 结点结构三叉链表表示法算法搜索结点的父结点搜索符合数据域条件的结点删除给定结点及其…

Brave编译指南2024 MacOS篇-更新与维护(七)

引言 在上一篇文章中,我们成功构建并运行了Brave浏览器。然而,浏览器开发是一个持续的过程,Brave和Chromium都在不断更新。本文将介绍如何保持你的Brave构建与最新版本同步,以及如何处理更新过程中可能遇到的问题。 1. 更新Brav…

HCIP--以太网交换安全(二)

端口安全 一、端口安全概述 1.1、端口安全概述:端口安全是一种网络设备防护措施,通过将接口学习的MAC地址设为安全地址防止非法用户通信。 1.2、端口安全原理: 类型 定义 特点 安全动态MAC地址 使能端口而未是能Stichy MAC功能是转换的…

【动态规划】斐波那契模型 dp

动态规划的步骤: 状态表示。所谓状态表示就是 dp 表里的值表示什么含义,那么状态表示怎么找呢? a. 题目要求 b. 经验(以某一个位置为结尾 / 起点) 题目要求 c. 分析问题的过程中发现重复子问题状态转移方程。dp[ i ] …

以矩阵的视角解多元一次方程组——矩阵消元

x 2 y z 2 x 2yz2 x2yz2 3 x 8 y z 12 3x8yz12 3x8yz12 4 y z 2 4yz2 4yz2 上面这是一个三元一次方程组,相信大家都知道如何解,现在这里给出另外一种视角,即从矩阵的角度来解方程组,从而学习在后面的线性代数学习中会用…

详解 SPI 机制

SPI(Service Provider Interface) 是 JDK 内置的一种服务提供发现机制:可以用来启用框架扩展和替换组件,主要用于框架中开发。例如:Dubbo、Spring、Common-Logging,JDBC 等都是采用 SPI 机制,针对同一接口采用不同的实…

Trickle流量限速工具使用示例

简介:trickle 是一个轻量级的流量限速工具,允许用户限制应用程序的网络带宽使用,以便更好地管理网络资源和优化网络性能。本文将介绍 trickle 的安装和使用方法,并通过 Python 封装示例展示如何使用 trickle 控制网络带宽。 历史…

计算机毕业设计 自习室座位预约系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍:✌从事软件开发10年之余,专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ 🍅文末获取源码联系🍅 👇🏻 精…