[转]C++结构体|类 内存对齐详解】的更多相关文章

内存地址对齐,是一种在计算机内存中排列数据(表现为变量的地址).访问数据(表现为CPU读取数据)的一种方式,包含了两种相互独立又相互关联的部分:基本数据对齐和结构体数据对齐 . 为什么需要内存对齐?对齐有什么好处?是我们程序员来手动做内存对齐呢?还是编译器在进行自动优化的时候完成这项工作? 在现代计算机体系中,每次读写内存中数据,都是按字(word,4个字节,对于X86架构,系统是32位,数据总线和地址总线的宽度都是32位,所以最大的寻址空间为232 = 4GB(也 许有人会问,我的32位XP用…
一.关键一点 最关键的一点:结构体在内存中是一个矩形,而不是一个不规则形状 二.编程实战 #include <stdlib.h> #include <stdio.h> struct A { int a; char b; }; int main() { struct A a; a.a = ; a.b = ; printf("%p\n", &a); system("pause"); } 结构体代码 我们可以看到前四个字节是int a的 后…
在C语言开发当中会遇到这样的情况: #include <stdio.h> struct test { int a; char b; }; int main(int argc, const char * argv[]) { printf("%lu\n", sizeof(struct test)); ; } sizeof操作输出的结果是8,可是int和char类型的长度加起来只有5,那么为什么输出了8呢? 这就牵扯到结构体的内存对齐问题,事实上,结构体中的变量在内存当中并不是以…
接上一篇:C语言内存对齐详解(1) VC对结构的存储的特殊处理确实提高CPU存储变量的速度,但是有时候也带来了一些麻烦,我们也屏蔽掉变量默认的对齐方式,自己可以设定变量的对齐方式.VC 中提供了#pragma pack(n)来设定变量以n字节对齐方式.n字节对齐就是说变量存放的起始地址的偏移量有两种情况: 第一.如果n大于等于该变量所占用的字节数,那么偏移量必须满足默认的对齐方式: 第二.如果n小于该变量的类型所占用的字节数,那么偏移量为n的倍数,不用满足默认的对齐方式. 结构的总大小也有个约束…
接上一篇:C语言内存对齐详解(2) 在minix的stdarg.h文件中,定义了如下一个宏: /* Amount of space required in an argument list for an arg of type TYPE. * TYPE may alternatively be an expression whose type is used. */ #define __va_rounded_size(TYPE) \ ((() / sizeof (int)) * sizeof (…
java.lang.String类内存问题详解 字符串理解的难点在于其在堆内存空间上的特殊性,字符串String对象在堆内存上有两种空间: 字符串池(String pool):特殊的堆内存,专门存放String对象,且不会有重复的值. 普通堆内存空间:此处的String对象一般是通过调用new操作符得到. 两种字符串内存空间处理字符串的优先级关系: 字符串池(String pool)对普通堆内存空间说: 凡是你拥有的.且不管你同样的内容有多少份,我一定会且只会保存一份: 我有的,你不必一定拥有.…
http://blog.csdn.net/xing_hao/article/details/6678048 一.内存对齐 许多计算机系统对基本类型数据在内存中存放的位置有限制,它们会要求这些数据的首地址的值是某个数k(通常它为4或8)的倍数,这就是所谓的内存对 齐,而这个k则被称为该数据类型的对齐模数(alignment modulus).当一种类型S的对齐模数与另一种类型T的对齐模数的比值是大于1的整数,我们就称类型S的对齐要求比T强(严格),而称T比S弱(宽 松).这种强制的要求一来简化了处…
1.什么是内存对齐 还是用一个例子带出这个问题,看下面的小程序,理论上,32位系统下,int占4byte,char占一个byte,那么将它们放到一个结构体中应该占4+1=5byte:但是实际上,通过运行程序得到的结果是8 byte,这就是内存对齐所导致的. //32位系统 #include<stdio.h> struct{ int x; char y; }s; int main() { printf("%d\n",sizeof(s); // 输出8 return 0; }…
Win32平台下的微软C编译器的对齐策略: 1) 结构体变量的首地址能够被其最宽基本类型成员的大小所整除: 备注:编译器在给结构体开辟空间时,首先找到结构体中最宽的基本数据类型,然后寻找内存地址能被该基本数据类型所整除的位置,作为结构体的首地址.将这个最宽的基本数据类型的大小作为上面介绍的对齐模数. 2) 结构体每个成员相对于结构体首地址的偏移量(offset)都是成员大小的整数倍,如有需要编译器会在成员之间加上填充字节: 备注:为结构体的一个成员开辟空间之前,编译器首先检查预开辟空间的首地址相…
C语言结构体指针详解 一.前言 一个指向结构体的变量的指针表示的是这个结构体变量占内存中的起始位置,同样它也可以指向结构体变量数组. *a).b 等价于 a->b. "."一般情况下读作"的”,结构体a的b. “->”一般读作"指向的结构体的",a指向的结构体的b. 二.实例 #include<stdlib.h> #include<stdio.h> #include <string.h> int main()…