博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
汇编语言 第二章 寄存器检测点2.2 第二题
阅读量:6149 次
发布时间:2019-06-21

本文共 1356 字,大约阅读时间需要 4 分钟。

hot3.png

这道题是汇编语言第二版的习题,一开始我也是百思不得其解,下面看看吧:

有一数据存放在内存20000H单元中,现给定段地址为SA,若想用偏移地址寻址到此单元,
则SA 应满足的条件是:最小为 1001H 最大为 2000H ;
最大值: (很多人最大值很容易算出来,但是最小值卡住了,很纳闷为什么是1001H)
我们可以根据原题列出一个式子: X * 10H + 0H = 20000H
我们之前是乘以16,但是那个16是十进制的,因为整个式子里都是16进制,加入个10进制去算会出错的
所以呢,我们把16转换为16进制的数,就是10H
段地址 = 物理地址 - 偏移地址 除以 10H
X = 20000H - 0H / 10H
求得结果是2000H
因为我们要求的是最大的段地址,所以就用上最小的偏移地址配合他,也就是0H
最小值:
SA * 16 + FFFFH = 20000H 段最小值那么就要用最大偏移地址来配合它。
SA * 16 = 20000H - FFFFH
SA * 16 = 10001H 我们求得了这个段地址,但是还要除以10H,或者转换为10进制,再除以10进制的16
(那为什么不是1000H呢?下面是daan……)
段地址要为16(10H)的倍数,
20000H - FFFF = 10001H 10001H十进制是65537,除以16是4096.0625 有小数说明不是倍数,不能整除
20000H - FFFE = 10002H 10002H十进制是65538,除以16是4096.125 有小数说明不是倍数,不能整除
20000H - FFFD = 10003H 10001H十进制是65539,除以16是4096.1875 有小数说明不是倍数,不能整除
20000H - FFFC = 10004H 10001H十进制是65540,除以16是4096.25 有小数说明不是倍数,不能整除
20000H - FFFB = 10005H 10001H十进制是65541,除以16是4096.3125 有小数说明不是倍数,不能整除
20000H - FFFA = 10006H 10001H十进制是65542,除以16是4096.375 有小数说明不是倍数,不能整除
(这些的值都不是16的倍数)
我们不断减小值,因为FFFF是最大,不能再大了,所以只能减小,直到....... (要直到除以16是整数为止)
20000H - FFF0 = 1 0010H 1 0010H十进制是65552,除以16是4097,可以整除
这时10010H满足16(10H)的倍数了
物理地址减去 [可以被16整除的最大偏移地址,在这一题中也就是FFF0H] 的结果,除以16(10H)等于最小段地址
20000H - FFF0H / 10H = 1001H ,于是这个1001H这个苦逼的孩子就是daan了。。。
提示,反过来思考一下,当段地址给定为多少,CPU无论怎么变化偏移地址都无法寻到20000H单元?
·根据上面一题的daan,小于1001H,或者大于2000H都无法寻到20000H单元

转载于:https://my.oschina.net/u/2423028/blog/488410

你可能感兴趣的文章
Spring常用注解
查看>>
我的友情链接
查看>>
PCS子层有什么用?
查看>>
查看端口,关闭端口
查看>>
代码托管平台简介
查看>>
linux:yum和apt-get的区别
查看>>
Sentinel 1.5.0 正式发布,引入 Reactive 支持
查看>>
数据库之MySQL
查看>>
2019/1/15 批量删除数据库相关数据
查看>>
数据类型的一些方法
查看>>
Mindjet MindManager 2019使用教程:
查看>>
游戏设计的基本构成要素有哪些?
查看>>
详解 CSS 绝对定位
查看>>
AOP
查看>>
我的友情链接
查看>>
NGUI Label Color Code
查看>>
.NET Core微服务之基于Polly+AspectCore实现熔断与降级机制
查看>>
vue组件开发练习--焦点图切换
查看>>
浅谈OSI七层模型
查看>>
Webpack 2 中一些常见的优化措施
查看>>