关于检测点2.2(2)的疑问
本帖最后由 selfLearn 于 2021-10-7 19:17 编辑原题目
我的思路
物理地址 = 段地址 * 16 + 偏移地址
物理地址 - 偏移地址 = 段地址 * 16 + 偏移地址 - 偏移地址
物理地址 - 偏移地址 = 段地址 * 16
将物理地址带入
当偏移地址最大时(FFFFH),SA(段地址)值最小。
20000H - FFFFH = 段地址 * 16
10001H /16 = 段地址
10001H / 10H = 段地址
1000H = 段地址
但是1000H * 16 + FFFFH = 1FFFFH
不等于 20000H
教材解题:
物理地址=SA*16+EA
20000h=SA*16+EA
SA = (20000h-EA)/16
= 2000h-EA/16
// 怎么SA挪过来就变成这样了,是什么数学定理?
EA取最大值时,SA=2000h-ffffh/16=1001h,SA为最小值
EA取最小值时,SA=2000h-0h/16=2000h,SA为最大值
我的思路一定是有问题,哪里出错了呢,教材的思路有一步没看懂,原谅我学历低。
啊 我明白了 不好意思啊 但是教材思路还是不太懂
物理地址 = 段地址 * 16 + 偏移地址
物理地址 - 偏移地址 = 段地址 * 16 + 偏移地址 - 偏移地址
物理地址 - 偏移地址 = 段地址 * 16
将物理地址带入
当偏移地址最大时(FFFFH),SA(段地址)值最小。
20000H - FFFFH = 段地址 * 16
// 这里FFFFH 没除 16
// 跟普通算数 先算括号里的顺序 还不一样哈
(20000H - FFFFH) / 16 = 段地址
2000H - FFFH = 段地址
1001H= 段地址
解题过程:
物理地址=SA*16+EA
20000h=SA*16+EA
SA=(20000h-EA)/16=2000h-EA/16
EA取最大值时,SA=2000h-ffffh/16=1001h,SA为最小值
EA取最小值时,SA=2000h-0h/16=2000h,SA为最大值
这里的ffffH/16=fffh是通过WIN自带计算器算的
按位移来算确实应该为fff.fh,这里小数点后的f应该是省略了
单就除法来说,应有商和余数,但此题要求的是地址最大和最小,所以余数忽略了
如果根据位移的算法(段地址*16=16进制左移一位),小数点后应该是不能省略的
我们可以反过来再思考下,如果SA为1000h的话,小数点后省略
SA=1000h,EA取最大ffffh,物理地址为1ffffh,将无法寻到20000H单元
这道题不应看成是单纯的计算题
{:5_95:}
页:
[1]