为什么64位系统默认是8字节对齐

几许清风 2016-12-02 03:43:39
32位的我已经大概了解了,因为地址总线的关系,有2根总线不参与寻址,导致只能获取到4的整数倍的地址,所以默认是4字节对齐。但是64位的8字节对齐我就不太理解了,有两个疑问:
(1)如果64位获取的地址只能是8的倍数,这不科学啊,如果是8的倍数为什么int类型用4字节就可以对齐啊(考虑起始地址不是8的倍数,但占4字节)?
(2)如果获取的地址不是8的倍数(如果也是4的倍数),指针类型的数据或者double类型的需要8字节才能对齐(同样使用4字对齐也完全可以一次获取啊)?
还是有其他什么概念 没理解到位的,有没有大神来解惑一下
...全文
1973 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
几许清风 2016-12-02
  • 打赏
  • 举报
回复
已经找到了原因了 大概是也为了性能考虑,8字节的数据需要8字节对齐和cpu缓冲命中率有关系 http://stackoverflow.com/questions/21219130/is-8-byte-alignment-for-double-type-necessary
赵4老师 2016-12-02
  • 打赏
  • 举报
回复
《The Intel 64 and IA-32 Architectures Software Developer's Manual》

70,017

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧