在这里就分享两条开发中曾经忽略的问题:
1、Union(联合体)的字节对齐
先看代码:
#pragma pack(4)
struct com
{
union
{
double dTest;
int nTest;
char szTest[14];
};
char chTest1;
char chTest2;
};
#pragma pack()
sizeof(struct com) = ?
gcc 4.1 和 vc 2005环境下,答案是20。
调试一下结构体的内存布局,发现,union自身增加了2个字节的填充,用来保持Union本身的4字节对齐。
即union在内存中变成:
union
{
double dTest;
int nTest;
char szTest[14];
byte Padding1[2];
};
这样union就变成了16字节,加上2个char类型的字节后,为了保持struct的自身字节对齐,在struct末尾再填充两字节.
最终结构体的内存布局是这样的:
#pragma pack(4)
struct com
{
union
{
double dTest;
int nTest;
char szTest[14];
byte Padding1[2];
};
char chTest1;
char chTest2;
byte Padding2[2];
};
#pragma pack()
2、不同编译器环境默认字节对齐的差别
做平台移植的同仁要注意了,遇到不确定的字节对齐问题,最好先亲自试一下,不能太想当然了:
(1)Win32下,VC编译器默认8字节对齐,而且支持1、2、4、8、16五种对齐方式。
(2)Linux 32下,GCC 4.1默认4字节对齐,支持1、2、4三种对齐方式。因此结构体
中即使遇到double、long long这样的8字节变量,仍然按4字节对齐。即使设定了#pragma pack(8)
(3)安卓4.0, arm cpu的NDK编译环境,默认情况下,遇到double、long long类型的变量时,不同于PC Linux 32,会按照8字节对齐方式对齐。
浅析C++字节对齐容易被忽略的两个问题_C 语言
时间: 2024-09-16 04:44:26
浅析C++字节对齐容易被忽略的两个问题_C 语言的相关文章
C++字节对齐容易被忽略的两个问题
今天我就和大家分享一下C++字节对齐容易被忽略的两个问题.以下问题也是我实际开发工作中遇到的,如果有不同意见欢迎交流 在这里就分享两条开发中曾经忽略的问题:1.Union(联合体)的字节对齐先看代码:#pragma pack(4) struct com { union { double dTest; int nTest; char szTest[14]; }; char chTest1; char chTest2; }; #pragma pack() sizeof(st
浅析C++中结构体的定义、初始化和引用_C 语言
定义:结构体(struct)是由一系列具有相同类型或不同类型的数据构成的数据集合,也叫结构. 声明一个结构体类型的形式是: 复制代码 代码如下: struct Student{ //声明一个结构体类型Student int num; //声明一个整形变量num char name[20]; //声明一个字符型数组name char sex; //声明一个字符型变量sex int age; //声明一个整形变量age float
浅析char 指针变量char *=p 这个语句的输出问题_C 语言
学习指针的时候我一直有个疑惑,请看下面的代码: #include <iostream> using std::cout; void main() { int num=5; int *nPtr=# cout<<nPtr;//输出指针的地址.但是会报错<<没有直接输出int *地址的功能 return ; } 但是,将int 改成char 类型就不会报错,可以输出字符串.同样是指针,这次为何没有输出地址(理应输出指针代表的地址,但是<<并没有重载
浅析C语言中strtol()函数与strtoul()函数的用法_C 语言
C语言strtol()函数:将字符串转换成long(长整型数)头文件: #include <stdlib.h> strtol() 函数用来将字符串转换为长整型数(long),其原型为: long int strtol (const char* str, char** endptr, int base); [参数说明]str 为要转换的字符串,endstr 为第一个不能转换的字符的指针,base 为字符串 str 所采用的进制. [函数说明]strtol() 会将参数 str 字符串根据参数 b
字节对齐(强制对齐以及自然对齐)
struct {}node; 32为的x86,window下VC下sizeof(node)的值为1,而linux的gcc下值为0: 一.WINDOWS下(VC--其实GCC和其原理基本一样,象这种问题,一般要查具体的编译器设置)字节对齐的规则: 1.一般设置的对齐方式为1,2,4字节对齐方式,VC一般默认为4字节(最大为8字节).结构的首地址必须是结构内最宽类型的整数倍地址:另外,结构体的每一个成员起始地址必须是自身类型大小的整数倍(需要特别注意的是windows下是这样的,但在linux的gc
浅谈VC中的字节对齐
原文地址:浅谈VC中的字节对齐 前几天时,在公司和同事说到了字节对齐,一直对这个概念比较模糊,只是在<程序员面试宝典>中看到过简单的描述和一些面试题.后来在论坛中有看到有朋友在询问字节对齐的相关问题,自己也答不上来,觉得应该研究一下,所以就有了这一篇博文,是对学习的一个总结,也是对成长轨迹的一个记录. 字节对齐,又叫内存对齐,个人理解就是一种C++中的类型在内存中空间分配策略.每一种类型存储的起始地址,都要求是一个对齐模数(alignment modulus)的整数倍.问题来了,为
pragma pack(非常有用的字节对齐用法说明)
强调一点: #pragma pack(4) typedef struct { char buf[3]; word a; }kk; #pragma pack() 对齐的原则是min(sizeof(word ),4)=2,因此是2字节对齐,而不是我们认为的4字节对齐. 这里有三点很重要:1.每个成员分别按自己的方式对齐,并能最小化长度2.复杂类型(如结构)的默认对齐方式是它最长的成员的对齐方式,这样在成员是复杂类型时,可以最小化长度3.对齐后的长度必须是成员中最大的对齐参数的整数倍,这样在处
C语言字节对齐详解
一.什么是对齐,以及为什么要对齐: 1. 现代计算机中内存空间都是按照byte划分的,从理论上讲似乎对任何类型的变量的访问可以从任何地址开始,但实际情况是在访问特定变量的时候经常在特定的内存地址访问,这就需要各类型数据按照一定的规则在空间上排列,而不是顺序的一个接一个的排放,这就是对齐. 2. 对齐的作用和原因:各个硬件平台对存储空间的处理上有很大的不同.一些平台对某些特定类型的数据只能从某些特定地址开始存取.其他平台可能没有这种情况,但是最常见的是如果不按照适合其平台的要求对数据存放进行对齐,
[面试经]字节对齐
一.快速理解 什么是字节对齐? 在C语言中,结构是一种复合数据类型,其构成元素既可以是基本数据类型(如int.long.float等)的变量,也可以是一些复合数据类型(如数组.结构.联合等)的数据单元.在结构中,编译器为结构的每个成员按其自然边界(alignment)分配空间.各个成员按照它们被声明的顺序在内存中顺序存储,第一个成员的地址和整个结构的地址相同. 为了使CPU能够对变量进行快速的访问,变量的起始地址应该具有某些特性,即所谓的"对齐". 比如4字节的int型,其起始地址应该