对几组sizeof信息的分析

原创 2004年06月23日 18:54:00
对于很多C++新手而言,对象或变量的sizeof信息总是让人捉摸不透,以下程序列举了几组典型的sizeof信息,希望能解答大家在使用sizeof时的疑问。
在列举这几个例子前需要说明以下几点:
1
、在Win32平台上,指针长度都是4字节,char*int*double*如此,vbptr(virtual base table pointer)、vfptr(virtual function table pointer)也是如此;
2
、对于结构体(或类),编译器会自动进行成员变量的对齐,以提高运算效率。自然对齐(natural alignment)也称默认对齐方式是按结构体的成员中size最大的成员对齐的,强制指定大于自然对齐大小的对齐方式是不起作用的(Specifying a packing level larger than the natural alignment of a type does not change the type alignment.)
3
、不推荐强制对齐,大量使用强制对齐会严重影响处理器的处理效率。

范例1(一个简单的C语言的例子)
void
 f(int arr[])
{

    cout << "sizeof(arr) = " << sizeof(arr) << endl; //当被作为参数进行传递时,数组失去了其大小信息
}

void
 main()
{

    char
 szBuf[] = "abc";
    cout << "sizeof(szBuf) = " << sizeof(szBuf) << endl; //输出数组占用空间大小

    char
* pszBuf = szBuf;
    cout << "sizeof(pszBuf) = " << sizeof(pszBuf) << endl; //输出的是指针的大小

    int
 iarr[3]; iarr;
    cout << "sizeof(iarr) = " << sizeof(iarr) << endl; //输出数组占用空间大小
    f(iarr);

    int
* piarr = iarr;
    cout << "sizeof(piarr) = " << sizeof(piarr) << endl; //输出指针的大小
}

范例2(一个涉及alignment的例子)
struct
 DATA1
{

    char
    c1; //偏移量0,累积size = 1
    char    c2; //偏移量1,累积size = 1 + 1 = 2
    short    si; //偏移量2,累积size = 2 + 2
};

struct
 DATA2
{

    char
    c1; //偏移量0,累积size = 1
    short    si; //偏移量1 + (1),累积size = 1 + (1) + 2 = 4
    char    c2; //偏移量4,累积size = 4 + 1 = 5,但按最大长度sizeof(short) = 2对齐,故最后取6
};

struct
 DATA3
{

    char
    c1; //偏移量0,累积size = 1
    double    d; //偏移量1 + (7),累积size = 1 + (7) + 8 = 16
    char    c2; //偏移量16,累积size = 16 + 1 = 17,但按最大长度sizeof(double) = 8对齐,故最后取24
};

#pragma pack(push,1) //强制1字节对齐
struct DATA4
{

    char
    c1; //偏移量0,累积size = 1
    double    d; //偏移量1,累积size = 1 + 8 = 9
    char    c2; //偏移量9,累积size = 9 + 1 = 10
};
#pragma pack(pop) //恢复默认对齐方式

struct
 DATA5
{

    char
    c1;
    double
    d;
    char
    c2;
};


void
 main()
{

    cout << "sizeof(DATA1) = " << sizeof(DATA1) << endl;
    cout << "sizeof(DATA2) = " << sizeof(DATA2) << endl;
    cout << "sizeof(DATA3) = " << sizeof(DATA3) << endl;
    cout << "sizeof(DATA4) = " << sizeof(DATA4) << endl;
    cout << "sizeof(DATA5) = " << sizeof(DATA5) << endl;
}


范例3(C++语言特征对sizeof的影响)
class
 CA
{
};


class
 CB : public CA
{

public
:
    void
 func() {}
};


class
 CC : virtual public CA
{
};


class
 CD
{

    int
 k; //私有成员
public:
    CD() {k = -1;}
    void
 printk() { cout << "k = " << k << endl; }
};


class
 CE : public CD
{
};


class
 CF
{

    virtual
 void func() {}
};


void
 main()
{

    cout << "sizeof(CA) = " << sizeof(CA) << endl; //为了区分不包含任何成员的类的不同的元素,编译器会自动为类添加一个匿名元素
    cout << "sizeof(CB) = " << sizeof(CB) << endl; //与上面类似,编译器也为CB添加了一个匿名元素
    cout << "sizeof(CC) = " << sizeof(CC) << endl; //虚拟继承中vbptr(virtual base table pointer)占用4个字节

    cout << "sizeof(CD) = " << sizeof(CD) << endl;
    cout << "sizeof(CE) = " << sizeof(CE) << endl; //访问权限控制是在编译期间由编译器控制的,所以虽然不能访问CD类的成员k,这里仍然占用了sizeof(int)大小的空间
    //下面的代码进一步说明上述观点,由于在复杂的类层次结构中,当涉及到虚函数或者虚拟继承等时,有些信息是运行期动态生成的,故请勿效仿以下方法对对象进行修改
    CE e;
    e.printk();
    memset(&e, 0, sizeof(CE));
    e.printk(); //从这里可以看出,上面的memset操作修改了CD类的私有成员k

    cout << "sizeof(CF) = " << sizeof(CF) << endl; //虚函数表指针占用4个字节
}

C++类的大小——sizeof(class)

第一:孔磊d class CBase { }; 运行cout sizeof(CBase)=1; 为什么空的什么都没有是1呢?查资料……查啊查……OK这里了:先了解一个概念:类的实例化,所谓类的...
  • yangyangye
  • yangyangye
  • 2014年08月03日 22:06
  • 6099

C/C++介绍sizeof函数

0. 前向声明 sizeof,一个其貌不扬的家伙,引无数菜鸟竟折腰,小虾我当初也没少犯迷糊,秉着“辛苦我一个,幸福千万人”的伟大思想,我决定将其尽可能详细的总结一下。 但当我总结的时候才发...
  • lj695242104
  • lj695242104
  • 2013年11月17日 19:55
  • 4015

sizeof运算符详细总结

sizeof运算符的系统总结标签:c/c++转自 http://blog.csdn.net/w57w57w57/article/details/6626840 简介   sizeof是C/C++中的关...
  • hust_sheng
  • hust_sheng
  • 2016年01月18日 16:36
  • 2377

sizeof对字符数组字符串使用

#include using namespace std; void main() { char a[]={'a','b','c'}; //不是以字符串形式初始化,因此没有添加/0标志...
  • u010630958
  • u010630958
  • 2014年07月17日 09:02
  • 665

sizeof及常见考题

sizeof是C/C++中的关键字,它是一个运算符,其作用是取得一个对象(数据类型或者数据对象)的长度(即占用内存的大小,以byte为单位)。 在C++中,变量和自定义类型可以不用加(),内置类型要...
  • myself00
  • myself00
  • 2014年10月27日 21:06
  • 612

sizeof(string)的问题(很经典)

今天看到一个代码,刚开始没有看明白,代码如下: #include #include using namespace std; void main() { string a="www.ok2002.co...
  • u014082714
  • u014082714
  • 2015年04月28日 12:57
  • 3288

sizeof浅析(三)——求类的大小

sizeof求类的大小和求结构体的大小,有一定的相似性,但又不完全相同,因为类存在这继承和派生、存在着虚函数。 1、空类大小 对于一个空类,使用sizeof求得其大小为1。 2、简单类 如下定义一个类...
  • szchtx
  • szchtx
  • 2013年08月24日 11:22
  • 5714

浅析C++中sizeof操作符的用法

1. 概要 sizeof是C/C++中的一个操作符(operator),作用就是返回一个对象或者类型所占的内存字节数。返回值类型为size_t,在头文件stddef.h中定义.这是一个依赖于编译系统...
  • wangshubo1989
  • wangshubo1989
  • 2015年08月31日 11:27
  • 1952

C语言:内存地址分析 & sizeof和strlen用法总结

还是在大学时代接触的C语言,当时学习数组、指针等概念时,怎一个“晕”字了得。最近在学习之余,疯狂地恶补了相关知识,故总结之,如有错误,请大家多多指点。 一、 内存地址分析 1) 先来看一个最基础的...
  • sinat_27706697
  • sinat_27706697
  • 2015年08月19日 22:42
  • 2287

sizeof(int)*p 表示什么意思?

sizeof(int)*p 表示什么意思?
  • weibo1230123
  • weibo1230123
  • 2017年07月12日 09:54
  • 829
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:对几组sizeof信息的分析
举报原因:
原因补充:

(最多只允许输入30个字)