pragma pack,字节对齐
关于字节对齐
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,字节对齐的更多相关文章
- #pragma pack(n)对齐格式
#pragma pack(n)对齐格式 #pragma pack(n) 是预处理器用来指定对齐格式的指令,表示n对齐.当元素字节小于n时,要扩展到n:若元素字节大于n则占用其实际大小. struct ...
- 关于结构体内存对齐方式的总结(#pragma pack()和alignas())
最近闲来无事,翻阅msdn,在预编译指令中,翻阅到#pragma pack这个预处理指令,这个预处理指令为结构体内存对齐指令,偶然发现还有另外的内存对齐指令aligns(C++11),__declsp ...
- #pragma pack(x) CPU对齐
编译器会尽量把成员对齐以提高内存的命中率.对齐是可以更改的,使用"#pragma pack(x)" 可以改变编译器的对齐方式. C++固有类型的对界取编译器对齐方式与自身大小中较小 ...
- #pragma pack的使用
#pragma pack的作用 程序编译器对变量的存储带有一定随机性,而pragma pack是一种字节对齐方法,采用人为设定的方式将存储数据按一定格式排布.百科中提到了其一种作用:有的平台每次读都是 ...
- #pragma pack(push) 和#pragma pack(pop) 以及#pragma pack()
我们知道结构体内存对齐字节可以通过#pragma pack(n) 的方式来指定. 但是,有没有想过一个问题,某些时候我想4字节对齐,有些时候我又想1字节或者8字节对齐,那么怎么解决这个问题呢? 此时, ...
- 详解C/C++中的的:#pragma pack(push) 、#pragma pack(pop) 和#pragma pack()
前言 我们知道结构体内存对齐字节可以通过#pragma pack(n) 的方式来指定. 但是,有没有想过一个问题,某些时候我想4字节对齐,有些时候我又想1字节或者8字节对齐,那么怎么解决这个问题呢? ...
- C语言字节对齐 __align(),__attribute((aligned (n))),#pragma pack(n)
转载地址 : http://blog.csdn.net/21aspnet/article/details/6729724 一.概念 对齐跟数据在内存中的位置有关.如果一个变量的内存地址正好位于它 ...
- pragma pack(非常有用的字节对齐用法说明)
强调一点: #pragma pack(4) typedef struct { char buf[3]; word a; }kk; #pragma pack() 对齐的原则是min(sizeof(wor ...
- 关于sizeof与#pragma pack 以及网络上关于字节对齐的一点感想
工作中面试中对于字节对齐基本上是必考一个知识点,而很多面试是网络上上原题.基本上背一背就可以写正确,而关于4字节对齐我相信很多人也只是一个基本地了解,对于一些题目就感觉有问题,而且很多blog后面仍然 ...
随机推荐
- 自己定义控件-DownSlidingDrawer
一.描写叙述 能够下拉的 SlidingDrawer 二.效果图 图片是网上找到,可是效果是一样的 三.源代码 https://github.com/mentor811/Demo_MySlidingD ...
- java基本的语法
Java语言发展史 课程大纲: Java语言发展史: 1.sun公司1995年推出,2009年Oracle公司收购sun: 下载: 1.到Oracle官网下载 Java体系与特点 课程大纲: J ...
- JavaScript中操作对象的属性
1.操作对象的属性 注意: 标签属性与DOM对象属性的相应关系: 绝大部分2者是同样的.如:imgobj.src属性相应<img src="" >中src属性,但也有例 ...
- Autoencoders and Sparsity(一)
An autoencoder neural network is an unsupervised learning algorithm that applies backpropagation, se ...
- AIX 适配器
1. 查看所有适配卡 lsdev -CHc adapter 2. 物理网卡适配卡 查看到物理网卡的个数与类型 lsdev -Cc adapter|grep ent 查看物理网卡具体插槽位( ...
- 竖向 两级手风琴 TAB 栏
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- nexus 搭建maven私服
1. nexus 下载地址 https://sonatype-download.global.ssl.fastly.net/nexus/oss/nexus-2.14.4-03-bundle.tar.g ...
- 洛谷 P1801 黑匣子_NOI导刊2010提高(06)(未完)
P1801 黑匣子_NOI导刊2010提高(06) 题目描述 Black Box是一种原始的数据库.它可以储存一个整数数组,还有一个特别的变量i.最开始的时候Black Box是空的.而i等于0.这个 ...
- 跟着鬼哥学so改动,三,作业篇
作业: 通过前面两篇文章的学习.请自行分析此应用,将当前用户类型改动为Gold Vip 用户. watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZ3VpZ3V ...
- 相似group by的分组计数功能
之前同事发过一个语句,实现的功能比較简单,相似group by的分组计数功能,由于where条件有like,又无法用group by来实现. SELECT a.N0,b.N1,c.N2,d.N3,e. ...