汇编语言——物理地址=段地址x16+偏移地址,检测点2.2
一、为什么 物理地址=段地址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的更多相关文章
- 物理地址 = 段地址*10H + 偏移地址
程序如何执行: CPU先找到程序在内存中的入口地址 -- 地址总线 (8086有20根地址总线,每一根可以某一时传0或1, 20位的二进制数字可以表示的不同的数字的个数是2^20=1048576 10 ...
- 物理地址为20位 如10000H 用段地址*16+偏移地址表示
段地质在cpu中,为16位 段地质*16则变成物理首地址20位,这个物理首地址必定是16的倍数. 偏移地址16位, 则表明一个段的大小为64k. 同时也表明16位地址的寻址能力为64kb
- CPU结构及段地址偏移地址的概念
原文地址:http://blog.csdn.net/yihuiworld/article/details/7533335#comments 程序如何执行: CPU先找到程序在内存中的入口地址 -- 地 ...
- 王爽汇编习题2.2(1):给定地址段为0001H,仅通过变化偏移地址寻址,CPU的寻址范围为____到____
此题解题背景默认为8080型CPU,地址总线为16根.(8080-16,8086-20,8088-20,80286-24,80386-32) 16根地址总线寻址能力:(2 ** 16) / 1024 ...
- 转: PE rva to raw 虚拟偏移地址和文件物理偏移地址
+---------+---------+---------+---------+---------+---------+| 段名称 虚拟地址 虚拟大小 物理地址 物理大小 标志 |+-------- ...
- 【PE结构】由浅入深PE基础学习-菜鸟手动查询导出表、相对虚拟地址(RVA)与文件偏移地址转换(FOA)
0 前言 此篇文章想写如何通过工具手查导出表.PE文件代码编程过程中的原理.文笔不是很好,内容也是查阅了很多的资料后整合出来的.希望借此加深对PE文件格式的理解,也希望可以对看雪论坛有所贡献.因为了解 ...
- java对象的内存布局(二):利用sun.misc.Unsafe获取类字段的偏移地址和读取字段的值
在上一篇文章中.我们列出了计算java对象大小的几个结论以及jol工具的使用,jol工具的源代码有兴趣的能够去看下.如今我们利用JDK中的sun.misc.Unsafe来计算下字段的偏移地址,一则验证 ...
- 怎样求结构体成员的偏移地址 || 结构体的 sizeof 总结
C 语言中同意将值为 0 的变量强制转换成任一类型的指针,转换结果是一个NULL指针. (type*)0 // 一个 type 类型的NULL指针 用这个指针訪问结构体内的成员是非法的,可是 & ...
- C++ 虚指针、成员变量与类对象的偏移地址
先给出一段代码实现 #include <iostream> using namespace std; class animal { protected: int age; public: ...
随机推荐
- python爬取哦漫画
import requests from lxml import etree from bs4 import BeautifulSoup import os from selenium import ...
- hadoop之yarn详解(基础架构篇)
本文主要从yarn的基础架构和yarn的作业执行流程进行阐述 一.yarn的概述 Apache Yarn(Yet Another Resource Negotiator的缩写)是hadoop集群资源管 ...
- [Note] Windows 10 Python 3.6.4 安装scrapy
直接使用pip install安装时会在安装Twisted出错,以下主要是解决Twisted的安装问题 1. 安装wheel pip install wheel 2. 安装Twisted 在Pytho ...
- ELK 学习笔记之 Logstash之output配置
Logstash之output配置: 输出到file 配置conf: input{ file{ path => "/usr/local/logstash-5.6.1/bin/spark ...
- 04-Django模型(1)
---恢复内容开始--- 模型 MTV图解 ORM ORM全拼:Object-Relation-Mapping翻译就是对象关系映射.在MVC/MTV设计模式中的Model模块中都包括ORM.主要实现模 ...
- 从0开始学FreeRTOS-(消息队列)-5
## 问题解答 曾经有人问我,FreeRTOS那么多API,到底怎么记住呢? 我想说,其实API不难记,就是有点难找,因为FreeRTOS的API很多都是带参宏,所以跳来跳去的比较麻烦,而且注释也很多 ...
- Linux配置python
文章出处 https://www.cnblogs.com/yhongji/p/9383857.html 我这里使用的时centos7-mini,centos系统本身默认安装有python2.x,版本 ...
- SparkStreaming整合Flume的pull报错解决方案
先说下版本情况: Spark 2.4.3 Scala 2.11.12 Flume-1.6.0 Flume配置文件: simple-agent.sources = netcat-source simpl ...
- 【NOIP模拟赛】小奇的矩阵
[题目背景] 小奇总是在数学课上思考奇怪的问题. [问题描述] 给定一个n*m的矩阵,矩阵中的每个元素aij为正整数. 接下来规定 1.合法的路径初始从矩阵左上角出发,每次只能向右或向下走,终点为右下 ...
- Spring基础(一)
一.Spring简介 Spring框架性质是属于容器性质的.容器中装什么对象就有什么功能.所以可以一站式开发(springmvc+ioc+spring jdbc).核心是IOC(控制反转)和AOP(面 ...