64位操做系统意味着其cpu拥有更大的寻址能力。理论上来讲,其性能相比于32位操做系统会提高1倍。可是这也须要在64位操做系统上运行的软件也是64位的。编程
软件中数据类型的的字节数大小其实和操做系统是多少位的没有关系,而是由编译器决定的。也就是说数据结构占多少位取决于在软件编译时咱们选择的是64位仍是32位的编译器。其具体占位数在编译器已经决定了。segmentfault
下面是不一样位数编译器下基本数据类型对应的字节数。数据结构
char:1个字节函数
char*(即指针变量):4个字节性能
shortint:2个字节学习
int:4个字节ui
unsignedint:4个字节spa
float:4个字节double:8个字节操作系统
long:4个字节指针
longlong:8个字节
unsignedlong:4个字节
char:1个字节
char*(即指针变量):8个字节
shortint:2个字节
int:4个字节
unsignedint:4个字节
float:4个字节
double:8个字节
long:8个字节
longlong:8个字节
unsignedlong:8个字节
总结:32位和64位编译器的基本数据类型字节数主要差异在64位的指针和long为8字节。
众所周知,为了保证每一个对象拥有彼此独立的内存地址,C++空类的内存大小为1字节。而非空类的大小与类中非静态成员变量和虚函数表的多少有关。其中,类中非静态成员变量的大小则与编译器的位数以及内存对齐的设置有关。
类中的成员变量在内存中并不必定是连续的。它是按照编译器的设置,按照内存块来存储的,这个内存块大小的取值,就是内存对齐。
内存对齐有2个规则:
第一个成员变量放在类中内存offset为0的地方,以后的成员变量的对齐按照#pragma pack(n)指定的数值和这个成员变量类型所占字节数中,比较小的那个进行(成员变量间补齐)。
在成员变量完成各自内存对齐以后,类(结构或联合)自己也要进行内存对齐,对齐按照#pragma pack(n)指定的数值和类中最大成员变量类型所占字节数中,比较小的那个进行(类中最后一个成员变量结尾后补齐),类大小须要是对齐值得整数倍。
\#pragma pack(n)做为一个预编译指令用来设置内存对齐的字节数。须要注意的是,n的缺省数值是编译器设置的,通常为8,合法的数值分别是一、二、四、八、16。
延伸知识:C++空类大小
C++标准指出,不容许一个对象(固然包括类对象)的大小为0,不一样的对象不能具备相同的地址。这是因为:
new须要分配不一样的内存地址,不能分配内存大小为0的空间
避免除以sizeof(T)时获得除以0错误故使用一个字节来区分空类。
须要注意的是,这并不表明一个空基类也须要加一个字节到子类中去。这种状况下,空基类并非独立的,它附属于子类。子类继承空基类后,子类若是有本身的数据成员,则空基类的那一个字节并不会加到子类中去。
若是你想更好的提高你的编程能力,学好C语言C++编程!弯道超车,快人一步!
【C语言C++学习企鹅圈子】,分享(源码、项目实战视频、项目笔记,基础入门教程)
欢迎转行和学习编程的伙伴,利用更多的资料学习成长比本身琢磨更快哦!
编程学习书籍:
编程学习视频:
文章来源:https://segmentfault.com/a/1190000038919912?utm_source=tuicool&utm_medium=referral