x86的字节对齐与不对齐的问题


比如这么一个结构体
struct foo {
short s;
int   n;
};

struct foo bar;
假设bar的地址是0x12345670
如果不按4字节对齐
那么bar.n的地址就是0x12345672, 也就是下面的黑体部分
0x12345670 a0 a1 a2 a3
0x12345674 b0 b1 b2 b3
为了取到n的值就需要访问两次内存,一次访问0x12345670,一次访问0x12345674
然后把两个int值组合在一起,a2 a3 b0 b1

http://www.doc88.com/p-205512154878.html   此文中说明更加详细易懂

 

 

市面上所说的64位处理器包括AMD Athlon 64与INTEL的EMT64处理器都是指通用寄存器的位宽,不是总线。
但要从数据总线方面来说,从80386开始就已经是32bit
而奔腾级别以上的CPU数据数据总线都是64bit了,包括安腾在内的64位服务器处理器。
而我们通常所说的32bit向64bit过度都是习惯上以通用寄存器的位宽来区分的。
还有一种更具体的说法是:
这里的64位技术是相对于32位而言的,这个位数指的是CPU GPRs(General-Purpose Registers,通用寄存器)的数据宽度为64位,
64位指令集就是运行64位数据的指令,也就是说处理器一次可以运行64bit数据。64bit处理器并非现在才有的,
在高端的RISC(Reduced Instruction Set Computing,精简指令集计算机)很早就有64bit处理器了,
比如SUN公司的UltraSparc Ⅲ、IBM公司的POWER5、HP公司的Alpha等。

 

 

 引用自 http://bbs.csdn.net/topics/390291667?page=1

http://www.cnblogs.com/lancidie/archive/2011/08/18/2144071.html

posted on 2013-09-29 11:42  xiaofangne  阅读(530)  评论(0编辑  收藏  举报

导航