关于字节对齐
pragma pack

一、

测试代码:

// packTest.cpp : Defines the entry point for the console application.
// #include "stdafx.h"
#include <iostream> using namespace std; /************************************************************************/
/* Defualt */
/************************************************************************/
class A0
{
char a;
int b;
double c;
bool d;
short e;
};
class A1
{
char a;
int b;
double c;
bool d;
};
class A2
{
char a;
int b;
double c;
};
class A3
{
char a;
int b;
};
class A
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
/*
事实上,很多人对#pragma pack的理解是错误的。
#pragma pack规定的对齐长度,实际使用的规则是:
结构,联合,或者类的数据成员,第一个放在偏移为0的地方,以后每个数据成员的对齐,
按照#pragma pack指定的数值和这个数据成员自身长度中,比较小的那个进行。
也就是说,当#pragma pack的值等于或超过所有数据成员长度的时候,这个值的大小将不产生任何效果。
而结构整体的对齐,则按照结构体中最大的数据成员 和 #pragma pack指定值 之间,较小的那个进行。
*/ /************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(1)
class B
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop) /************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(2)
class BB
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop) /************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(4)
class C
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop) /************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(8)
class D
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop) int _tmain(int argc, _TCHAR* argv[])
{
cout<<"char : "<<sizeof(char)<<" byte \n";
cout<<"int : "<<sizeof(int)<<" byte \n";
cout<<"double : "<<sizeof(double)<<" byte \n";
cout<<"bool : "<<sizeof(bool)<<" byte \n";
cout<<"short : "<<sizeof(short)<<" byte \n";
cout<<"/*---------------------------------------------*/"<<"\n";
cout<<"Default aligned A3:"<<sizeof(A3)<<"\n";
cout<<"Default aligned A2:"<<sizeof(A2)<<"\n";
cout<<"Default aligned A1:"<<sizeof(A1)<<"\n";
cout<<"Default aligned A0:"<<sizeof(A0)<<"\n";
cout<<"Default aligned A:"<<sizeof(A)<<"\n";
cout<<"1 aligned:"<<sizeof(B)<<"\n";
cout<<"2 aligned:"<<sizeof(BB)<<"\n";
cout<<"4 aligned:"<<sizeof(C)<<"\n";
cout<<"8 aligned:"<<sizeof(D)<<"\n";
return 0;
}

二、测试结果

三 、各类说明分析

/************************************************************************/
/* Defualt */
/************************************************************************/
class A0
{
/*
* 默认为 8 字节对齐
*/
char a;
int b;
double c;
bool d;
short e;
};
class A1
{
char a;
int b;
double c;
bool d;
};
class A2
{
char a;
int b;
double c;
};
class A3
{
char a;
int b;
};
class A
{
char a;
int b;
double c;
bool d;
short e;
char f;
};

/************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(1)
class B
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop)

/************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(2)
class BB
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop)

/************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(4)
class C
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop)

/************************************************************************/
/* */
/************************************************************************/
#pragma pack(push)
#pragma pack(8)
class D
{
char a;
int b;
double c;
bool d;
short e;
char f;
};
#pragma pack(pop)

参考:http://msdn.microsoft.com/zh-cn/library/2e70t5y1(v=vs.90).aspx

***************************************************************************

Specifies the value, in bytes, to be used for packing. The default
value for n is
8. Valid values are 1, 2, 4, 8, and 16. The alignment of a member will be on a boundary that is either a multiple of n or
a multiple of the size of the member, whichever is smaller.

源码下载地址:http://download.csdn.net/detail/cartzhang/6792147

本博客源码链接地址

----------------------------------

若有 问题,请不吝赐教。

非常感谢!

pragma pack,字节对齐的更多相关文章

  1. #pragma pack(n)对齐格式

    #pragma pack(n)对齐格式 #pragma pack(n) 是预处理器用来指定对齐格式的指令,表示n对齐.当元素字节小于n时,要扩展到n:若元素字节大于n则占用其实际大小. struct ...

  2. 关于结构体内存对齐方式的总结(#pragma pack()和alignas())

    最近闲来无事,翻阅msdn,在预编译指令中,翻阅到#pragma pack这个预处理指令,这个预处理指令为结构体内存对齐指令,偶然发现还有另外的内存对齐指令aligns(C++11),__declsp ...

  3. #pragma pack(x) CPU对齐

    编译器会尽量把成员对齐以提高内存的命中率.对齐是可以更改的,使用"#pragma pack(x)" 可以改变编译器的对齐方式. C++固有类型的对界取编译器对齐方式与自身大小中较小 ...

  4. #pragma pack的使用

    #pragma pack的作用 程序编译器对变量的存储带有一定随机性,而pragma pack是一种字节对齐方法,采用人为设定的方式将存储数据按一定格式排布.百科中提到了其一种作用:有的平台每次读都是 ...

  5. #pragma pack(push) 和#pragma pack(pop) 以及#pragma pack()

    我们知道结构体内存对齐字节可以通过#pragma pack(n) 的方式来指定. 但是,有没有想过一个问题,某些时候我想4字节对齐,有些时候我又想1字节或者8字节对齐,那么怎么解决这个问题呢? 此时, ...

  6. 详解C/C++中的的:#pragma pack(push) 、#pragma pack(pop) 和#pragma pack()

    前言 我们知道结构体内存对齐字节可以通过#pragma pack(n) 的方式来指定. 但是,有没有想过一个问题,某些时候我想4字节对齐,有些时候我又想1字节或者8字节对齐,那么怎么解决这个问题呢? ...

  7. C语言字节对齐 __align(),__attribute((aligned (n))),#pragma pack(n)

    转载地址 : http://blog.csdn.net/21aspnet/article/details/6729724 一.概念    对齐跟数据在内存中的位置有关.如果一个变量的内存地址正好位于它 ...

  8. pragma pack(非常有用的字节对齐用法说明)

    强调一点: #pragma pack(4) typedef struct { char buf[3]; word a; }kk; #pragma pack() 对齐的原则是min(sizeof(wor ...

  9. 关于sizeof与#pragma pack 以及网络上关于字节对齐的一点感想

    工作中面试中对于字节对齐基本上是必考一个知识点,而很多面试是网络上上原题.基本上背一背就可以写正确,而关于4字节对齐我相信很多人也只是一个基本地了解,对于一些题目就感觉有问题,而且很多blog后面仍然 ...

随机推荐

  1. 洛谷—— P1086 花生采摘

    https://www.luogu.org/problem/show?pid=1086#sub 题目描述 鲁宾逊先生有一只宠物猴,名叫多多.这天,他们两个正沿着乡间小路散步,突然发现路边的告示牌上贴着 ...

  2. 整合struts2+spring+hibernate

     一.准备struts2+spring+hibernate所须要的jar包:        新建web项目并将jar包引入到project项目中. 二.搭建struts2环境        a.在 ...

  3. 蓝的成长记——追逐DBA(10):飞刀防身,熟络而非专长:摆弄中间件Websphere

    原创作品,出自 "深蓝的blog" 博客.欢迎转载,转载时请务必注明出处.否则追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlong ...

  4. JAVA学习第五十四课 — IO流(八)打印流 &amp; 序列流

    一.综合练习-文件清单列表 获取指定文件夹下,指定扩展名的文件(含子文件夹),并将这些文件的绝对路径写到一个文本文件里.也就是建立一个指定扩展名的文件列表 1.深度遍历 2.过滤器->容器 3. ...

  5. js---04 属性 this

    var oUl = document.getElementsByTagName('ul')[0]; var aLi = oUl.getElementsByTagName('li'); window.o ...

  6. MyBatis自动生成代码之generatorConfig配置文件及其详细解读

    <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE generatorConfiguratio ...

  7. 带你底层看Sqoop如何转换成MapReduce作业运行的(代码程序)

    补充 其实啊,我们知道,sqoop在运行的时候,最终会去转换成mapreduce作业,这个很简单,不多赘述.直接贴出来. 具体这些怎么运行的,见我如下这篇博客.这里只做一个引子. Sqoop Impo ...

  8. 今日题解------codeforce 893d

    题意:给你一个数列,小于零表示表示信用卡里取出钱,大于零表示信用卡里存钱,等于零表示要查询信用卡, 如果被查到信用卡里的钱小于零,那你就GG,或者在任何时候你的信用卡里的钱大于d的话(不需要找ai等于 ...

  9. 请妥善保管自己的QQ等网络帐号

    自从2008年以来,太多的同学.朋友,QQ等网络帐号被盗. 然后,盗号者来骗钱.比如 借用账号.帮忙支付费用等. 盗号者固然可恶,传统骗子的网络版. 可是,这些帐号的主人就仅仅是可怜么? 自己的号被盗 ...

  10. hdu 1233 还是畅通project (克鲁斯卡尔裸题)

    还是畅通project                                              Time Limit: 4000/2000 MS (Java/Others)    M ...