C 知道
阅读了一篇文章https://www.cnblogs.com/VIPler/p/4282584.html里面有这样一段话“至于说为什么会出现一种是用4位十六进制表示内存地址,另一种用8位十六进制表示内存地址,那是根据不同的硬件环境来的。个人理解:有些CPU只能寻址16位(16根地址线),所以用4位十六进制表示地址就够用了。有些CPU只能寻址32位(32根地址线),所以用8位十六进制。”请问为什么4位十六进制就是cpu只能寻址16位,8位就是能寻址32位。
收起
首先那篇文章说错了,0x0001不是4位,而是16位,当然可能你会说是四个数字所以叫4位,那按你那样说也可以,但一般是说16位的,而0x00000001是叫32位。
至于为什么,是因为历史原因决定的,原来的机器是按4位、8位、16位、32位发展起来的,现在机器都到64位了。但8086中间有个过渡设计,就是地址线是20位,寄存器又是16位的,这个地址就要用0x0000:0x0001,来表示,在32位时代地址可以直接用32位寄存器表示,就是你说的0x00000001这种地址,它跟0x0000:0x0001表示的是不同模式下的同一个地址。所以有时用0x0001有时又是0x000000001,其实还有很多细节可以讨论,写出来就是一大篇幅了
手机打字的,说的有点乱,不知道理解了没,总的来说就是为了兼容历史问题而造成两种表示方法
补充回答你最后的问题,4位16进制对应的是16位二进制,刚好对应16根地址线,8位十六进制同理是32位二进制,对应32根地址线
牛逼!清楚易懂
多谢哈
报告相同问题?
程序员都在用的中文IT技术交流社区
专业的中文 IT 技术社区,与千万技术人共成长
关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!