一、#pragma简介
#pragma是预处理指令的一种,它的作用是设定编译器的状态、指定编译器完成特定任务。
(预处理阶段:在编译阶段之前进行)
#pragma相当于是由各个厂商开发扩展的,因此可能因编译器或操作系统不同而有所差异。
(以上的意思是:不是所有编译器都一定能用所有的#pragma)
二、#pragma pack(n)
#pragma pack(n)的作用是重新设定内存对齐的长度大小为n(单位为:字节),有关内存对齐模式,请参考我之前写的《C++内存对齐原则》。
举一个简单的例子,便于大家理解:
#include <iostream>
#include <string>
using namespace std;
struct A {
char a;
int b;
short c;
};
int main() {
cout << "Without \"#pragma pack(n)\", sizeof(A) : " << sizeof(A) << endl;// 12
return 0;
}
以上结构体,按照内存对齐原则,长度应该为12。以下为输出结果:
如果我们在结构体A定义的前边加上:#pragma pack(2)
表示接下来内存按照对齐长度为2的方式定义:
#include <iostream>
#include <string>
using namespace std;
#pragma pack(2)
struct A {
char a;
int b;
short c;
};
int main() {
cout << "With \"#pragma pack(n)\", sizeof(A) : " << sizeof(A) << endl;// 8
return 0;
}
结果长度为8,程序输出如下所示:
三、#pragma pack()
当使用#pragma pack(n)后,接下来所有的代码都会按照内存对齐长度为n的方式进行。
此时如果我们想还原,也就是希望接下来的代码,按照默认内存对齐原则的方式进行,此时应该使用#pragma pack()。示例如下:
#include <iostream>
#include <string>
using namespace std;
#pragma pack(2)
struct A {
char a;
int b;
short c;
};
#pragma pack()
struct B {
char a;
int b;
short c;
};
int main() {
cout << "sizeof(A) : " << sizeof(A) << endl; //8
cout << "sizeof(B) : " << sizeof(B) << endl; //12
return 0;
}
在A的定义结尾使用#pragma pack()之后,B的长度按照4字节对齐的长度为12,而不是按照上边A的2字节对齐(结果为8),程序输出结果如下: