一、为什么 物理地址=段地址x16+偏移地址?

刚开始学时,我都笨到不明白为什么是2的N次方,咱把物理地址就当数字,计算机中数字是由很多位0或1自由组合的, 而每一位上要么是0要么是1,只有这两种情况,所以N位就可以组成2的N次方个编号地址了

  8086CPU的地址总线是20条(位),因此就可以给104 8576个(1M)内存单元进行地址编号,而寄存器和数据总线都是16位的,16位对应6 5536(64K),这样就浪费了好多好多内存空间啊,咋办?于是那些聪明人整了个地址加法器,地址加法器干的活计就是把16位的段地址乘以16,为啥非得是16呢?我让你干件事:你把数字68左移一位是多少,你告诉我680,没错,你把68后面补个0 其实就是乘以了10,我再让你把十六进制38H左移一位你还是像刚才那么干在后面补个0是380H,其实还是乘以了10H, 而这里的10H对应十进制16,1位十六进制对应4位二进制,所以段地址乘以十进制的16,就是相当于在一个16位的二进制数后面补了4个0,哇这不就凑成了20位,内存就避免了浪费,乘完16得到了一个首地址(起始地址/基础地址),把首地址作为一个起始地址加上一个16位二进制偏移地址,偏移地址的偏移量是0H~FFFFH(因为16位二进制数最大是FFFFH),所以段空间最大是64K(FFFFH),我们以后就可以根据需要逻辑上把内存分段进行内存空间的访问。

二、段地址x16是一个16的倍数

一看标题这不废话吗。。。直到看到王爽老师《汇编语言》检测点2.2,加深了对这句话的理解

我们就做最小为多少,根据公式很容易想到,当偏移地址最大为FFFFH时 段地址SA肯定最小啊

①SAx16+FFFFH=20000H

②SAx16=20000H-FFFFH=10001H

③SA=10001H/16(10H)=1000H

这也太简单了吧,百度下看看答案对不对,纳尼答案咋是1001H,哪来的啊?我算错了???算了好几次都是1000H啊,咋回事?

  我们注意②SAx16=20000H-FFFFH=10001H,我们再看一眼标题二,10001H=65537 显然不是16的倍数啊,然后我们就把之前用的FFFF换成FFFF-1,FFFF-2,FFFF-3...直到试到FFFF-F=FFF0H时得到了16的倍数和正确答案吻合了。但这样操作好累啊,一个一个试,所以快速的做法是反过来想:我要保证首地址是一个16的倍数,从十六进制角度看就是要保证末尾是个0,

所以20000H-?=末尾是0的数,显然FFF后面带个0就能跟20000H末尾的0对应相减得到末尾是0的数。

  总结:内存中有些内存单元不能作为段的首地址(段地址x16),因为有些物理地址不是16(10H)的倍数,但是段地址可以是任何地址因为它要乘16,无论地址是多少都可以,注意我这里说的段地址并不是内存中的地址,因为段地址是16位,内存的物理地址是20位,前面说的首地址(在偏移为0的情况下)可以看成内存中段的起始物理地址,但这不表示那些不能做首地址的内存单元访问不到,因为一个内存单元的物理地址可以根据段地址和偏移地址有很多种组合来访问它。

若有错误,请评论指正,谢谢!

汇编语言——物理地址=段地址x16+偏移地址,检测点2.2的更多相关文章

  1. 物理地址 = 段地址*10H + 偏移地址

    程序如何执行: CPU先找到程序在内存中的入口地址 -- 地址总线 (8086有20根地址总线,每一根可以某一时传0或1, 20位的二进制数字可以表示的不同的数字的个数是2^20=1048576 10 ...

  2. 物理地址为20位 如10000H 用段地址*16+偏移地址表示

    段地质在cpu中,为16位 段地质*16则变成物理首地址20位,这个物理首地址必定是16的倍数. 偏移地址16位, 则表明一个段的大小为64k. 同时也表明16位地址的寻址能力为64kb

  3. CPU结构及段地址偏移地址的概念

    原文地址:http://blog.csdn.net/yihuiworld/article/details/7533335#comments 程序如何执行: CPU先找到程序在内存中的入口地址 -- 地 ...

  4. 王爽汇编习题2.2(1):给定地址段为0001H,仅通过变化偏移地址寻址,CPU的寻址范围为____到____

    此题解题背景默认为8080型CPU,地址总线为16根.(8080-16,8086-20,8088-20,80286-24,80386-32) 16根地址总线寻址能力:(2 ** 16) / 1024 ...

  5. 转: PE rva to raw 虚拟偏移地址和文件物理偏移地址

    +---------+---------+---------+---------+---------+---------+| 段名称 虚拟地址 虚拟大小 物理地址 物理大小 标志 |+-------- ...

  6. 【PE结构】由浅入深PE基础学习-菜鸟手动查询导出表、相对虚拟地址(RVA)与文件偏移地址转换(FOA)

    0 前言 此篇文章想写如何通过工具手查导出表.PE文件代码编程过程中的原理.文笔不是很好,内容也是查阅了很多的资料后整合出来的.希望借此加深对PE文件格式的理解,也希望可以对看雪论坛有所贡献.因为了解 ...

  7. java对象的内存布局(二):利用sun.misc.Unsafe获取类字段的偏移地址和读取字段的值

    在上一篇文章中.我们列出了计算java对象大小的几个结论以及jol工具的使用,jol工具的源代码有兴趣的能够去看下.如今我们利用JDK中的sun.misc.Unsafe来计算下字段的偏移地址,一则验证 ...

  8. 怎样求结构体成员的偏移地址 || 结构体的 sizeof 总结

    C 语言中同意将值为 0 的变量强制转换成任一类型的指针,转换结果是一个NULL指针. (type*)0 // 一个 type 类型的NULL指针 用这个指针訪问结构体内的成员是非法的,可是 & ...

  9. C++ 虚指针、成员变量与类对象的偏移地址

    先给出一段代码实现 #include <iostream> using namespace std; class animal { protected: int age; public: ...

随机推荐

  1. 2019-ccpc秦皇岛现场赛

    https://www.cnblogs.com/31415926535x/p/11625462.html 昨天和队友模拟了下今年秦皇岛的区域赛,,,(我全程在演 题目链接 D - Decimal 签到 ...

  2. 记录使用echarts的graph类型绘制流程图全过程(一)-x,y位置的计算

    先说下本次案例业务需求,输入2个节点,获取数据后绘制出2个节点间的路径,之前使用的是网状图,但是网状图的效果不佳,需要转换成流程图的模式: 那么如何在不修改数据的情况下,实现类似效果尼? 看了下ech ...

  3. git clone 解决Permission Denied (publickey)问题

    本地git bash 使用git clone git@github.com:***.git方式下载github代码至本地时需要依赖ssh key,遇到权限不足问题时一般都是SSH key失效或者SSH ...

  4. python爬虫——京东评论、jieba分词、wordcloud词云统计

    接上一章,动态页面抓取——抓取京东评论区内容. url=‘https://club.jd.com/comment/productPageComments.action?callback=fetchJS ...

  5. HTML5 相关扩展

    一.与类相关的扩展 class属性的应用极其广泛,与class的相关的操作也越来越简化,HTML5增加了 getElementsByClassName来查找元素,通过也增加了classList属性,方 ...

  6. 一文彻底理解Redis序列化协议,你也可以编写Redis客户端

    前提 最近学习Netty的时候想做一个基于Redis服务协议的编码解码模块,过程中顺便阅读了Redis服务序列化协议RESP,结合自己的理解对文档进行了翻译并且简单实现了RESP基于Java语言的解析 ...

  7. springboot+thymeleaf国际化方法一:LocaleResolver

    springboot中大部分有默认配置所以开发起项目来非常迅速,仅对需求项做单独配置覆盖即可 spring采用的默认区域解析器是AcceptHeaderLocaleResolver,根据request ...

  8. A Deep Neural Network Approach To Speech Bandwidth Expansion

    题名:一种用于语音带宽扩展的深度神经网络方法 作者:Kehuang Li:Chin-Hui Lee 2015年出来的 摘要 本文提出了一种基于深度神经网络(DNN)的语音带宽扩展(BWE)方法.利用对 ...

  9. A-05 前向选择法和前向梯度法

    目录 前向选择法和前向梯度法 一.前向选择法 1.1 余弦相似度求投影 1.2 举例 1.3 前向选择法优缺点 1.3.1 优点 1.3.2 缺点 二.前向梯度法 2.1 举例 2.2 前向梯度法优缺 ...

  10. 【NOIP2009】道路游戏

    Description 小新正在玩一个简单的电脑游戏. 游戏中有一条环形马路,马路上有 nn 个机器人工厂,两个相邻机器人工厂之间由一小段马路连接.小新以某个机器人工厂为起点,按顺时针顺序依次将这 n ...