sizeof详解---1

转载 2006年06月04日 14:13:00

 关键字:sizeof,字节对齐,多继承,虚拟继承,成员函数指针

前向声明:
    sizeof,一个其貌不扬的家伙,引无数菜鸟竟折腰,小虾我当初也没少犯迷糊,秉着“辛苦我一个,幸福千万人”的伟大思想,我决定将其尽可能详细的总结一下。
    但当我总结的时候才发现,这个问题既可以简单,又可以复杂,所以本文有的地方并不适合初学者,甚至都没有必要大作文章。但如果你想“知其然,更知其所以然”的话,那么这篇文章对你或许有所帮助。
    菜鸟我对C++的掌握尚未深入,其中不乏错误,欢迎各位指正啊

1. 定义:
    sizeof是何方神圣sizeof乃C/C++中的一个操作符(operator)是也,简单的说其作用就是返回一个对象或者类型所占的内存字节数。

MSDN上的解释为:
The sizeof keyword gives the amount of storage, in bytes, associated with a variable or a type (including aggregate types). This keyword returns a value of type size_t.
    其返回值类型为size_t,在头文件stddef.h中定义。这是一个依赖于编译系统的值,一般定义为
typedef unsigned int size_t;
    世上编译器林林总总,但作为一个规范,它们都会保证char、signed char和unsigned
char的sizeof值为1,毕竟char是我们编程能用的最小数据类型。

2. 语法:
    sizeof有三种语法形式,如下:
    1) sizeof( object ); // sizeof( 对象 );
    2) sizeof( type_name ); // sizeof( 类型 );
    3) sizeof object; // sizeof 对象;
所以,
int i;
sizeof( i ); // ok
sizeof i; // ok
sizeof( int ); // ok
sizeof int; // error
    既然写法3可以用写法1代替,为求形式统一以及减少我们大脑的负担,第3种写法,忘掉它吧!实际上,sizeof计算对象的大小也是转换成对对象类型的计算,也就是说,同种类型的不同对象其sizeof值都是一致的。这里,对象可以进一步延伸至表达式,即sizeof可以对一个表达式求值,编译器根据表达式的最终结果类型来确定大小,一般不会对表达式进行计算。如:
sizeof( 2 ); // 2的类型为int,所以等价于 sizeof( int );
sizeof( 2 + 3.14 );  // 3.14的类型为double,2也会被提升成double类型,所以等价于 sizeof( double );

    sizeof也可以对一个函数调用求值,其结果是函数返回类型的大小,函数并不会被调用,我们来看一个完整的例子:
char foo()
{
    printf("foo() has been called./n");
    return 'a';
}
int main()
{
    size_t sz = sizeof( foo() ); // foo() 的返回值类型为char,所以sz = sizeof(char ),foo()并不会被调用
    printf("sizeof( foo() ) = %d/n", sz);
}

    C99标准规定,函数、不能确定类型的表达式以及位域(bit-field)成员不能被计算sizeof值,即下面这些写法都是错误的:
    sizeof( foo );// error
    void foo2() { }
    sizeof( foo2() );// error
    struct S
    {
        unsigned int f1 : 1;
        unsigned int f2 : 5;
        unsigned int f3 : 12;
    };
    sizeof( S.f1 );// error

3. sizeof的常量性
    sizeof的计算发生在编译时刻,所以它可以被当作常量表达式使用,如:
char ary[ sizeof( int ) * 10 ]; // ok
    最新的C99标准规定sizeof也可以在运行时刻进行计算,如下面的程序在Dev-C++中可以正确执行

((sizeof(n)+sizeof(int)-1)&~(sizeof(int)-1))

一、问题的提出 两年之前我写过一篇可变参数学习笔记,里面曾经简单的解释过一句: 代码 ((sizeof(n)+sizeof(int)-1)&~(sizeof(int)-1)) 的作用是在考虑字...
  • sonbai
  • sonbai
  • 2012年12月12日 13:36
  • 1103

类的大小——sizeof 的研究(1)

先看一个空的类占多少空间? class Base{public: Base(); ~Base();};      注意到我这里显示声明了构造跟析构,但是sizeof(Base)的结果是1.     因...
  • hairetz
  • hairetz
  • 2009年05月12日 17:09
  • 20431

sizeof操作符详解一

更多精彩内容,请见:http://www.16boke.com by zxy,Java/C++编程交流群:168424095 讨论及测试基础是Windows 32位平台,VS2008开发工具: 测试...
  • one_in_one
  • one_in_one
  • 2013年01月08日 09:22
  • 1260

_INTSIZEOF(n)

最近调试程序,遇到了可变长参数,
  • u010476094
  • u010476094
  • 2014年09月24日 21:09
  • 757

C语言中sizeof用法详解

文章转载自:http://bbs.ednchina.com/BLOG_ARTICLE_268624.HTM 大部分公司在招聘技术职位中,面试的时候,都会考大家的c语言基础,而sizeof是他们最喜欢...
  • weijianmeng
  • weijianmeng
  • 2012年10月19日 15:29
  • 2578

(void)sizeof(type_must_be_complete)检查不完全类型

检查不完全类型: 举例如下 //BB.h #include 2 class BB 3 { 4 public: 5 BB() 6 { 7 ...
  • lhh1113
  • lhh1113
  • 2017年02月21日 05:39
  • 207

1、空类的sizeof为1,为什么?

一个类的实例化对象所占空间的大小? 注意不要说类的大小,是类的对象的大小。 首先,类的大小是什么?确切的说,类只是一个类型定义,它是没有大小可言的。 用sizeof运算符对一个类型名操作,得到的是具...
  • ccy365263452
  • ccy365263452
  • 2016年10月31日 08:53
  • 1015

memset(a, -1, sizeof(int)) 的理解

-1的二进制表示1111... 32个1组成 memset是以字节为单位进行设置的 memset(a, -1, sizeof(int))设置sizeof(int)即4个四节,也就是设置a[0] ...
  • mingzhentanwo
  • mingzhentanwo
  • 2014年12月24日 11:40
  • 1121

memset(a,-1,sizeof(a));

// INTmemset.cpp : Defines the entry point for the console application. // #include "stdafx.h" #inc...
  • autumn20080101
  • autumn20080101
  • 2012年09月21日 19:29
  • 689

Google C++ 风格指南 :尽可能用 sizeof(varname) 代替 sizeof(type).

5.18. sizeof Tip 尽可能用 sizeof(varname) 代替 sizeof(type). 使用 sizeof(varname) 是因为当代码中变量类型改变时会自动更新. ...
  • thinkerleo1997
  • thinkerleo1997
  • 2017年11月29日 17:12
  • 46
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:sizeof详解---1
举报原因:
原因补充:

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