x86在内存不对齐的时候,为什么不会产生总线错误?
在有些机器上(例如sun的spark,intel的itanium),内存不对齐就会产生总线错误,例如下面这两行C代码:
char buf[8];
int* pi=buf+1;
(*pi)=2;
在spark上面就打印Bus error然后core dump。
但是在PC上面就能顺利通过,没有什么问题。
能否简单的解释一下呢,x86是怎么通过的,设计上有什么不一样?
我初学,请大虾就这个问题给个容易懂的解释,而不是建议我去啃某本大砖头,谢谢了!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(9)
另外,是SPARC,不是spark
从不关心奇地址,只注重实现,不注重效率
记得书上说X86的内存地址的9位每字节,有一位奇偶校验位,是由硬件自动添上的。另外也煞有介事的说内存地址不对齐的代价是很大的。。
本帖最后由 cjaizss 于 2010-12-08 08:39 编辑
X86是CISC机器,且支持奇数边界访问的CISC.这多少是牺牲了效率换来的,尽管有一套完备的比如cache机制什么的。不过现在似乎看起来也相差无几。而RISC,则一般不支持奇边界。
楼主用spark平台?做什么的呢?
同意3楼
在x86里,如果寻址不align,首先效率上要打些折扣~
X86上有些支持非对齐访存的指令,另外,操作系统也可以handle一些bus error错误。
没什么设计上的不同。这种非对齐访存基本内部实现都是用两条对齐操作,加一个拼装操作完成,效率很低。
the art of design is "TradeOff"