sizeof并不是一个函数,而更像是一个特殊的宏,它是在编译期间求值的。如如下的题目:
函数
int a = 0; cout << sizeof(a=3) << endl; cout << a << endl;
输出结果为4,0,那么为何不是4,3呢?缘由就在于sizeof不能被编译成机器码,那么其做用范围内的内容不能被编译,而是被替换成类型,=操做符返回左操做数的类型。因此sizeof不支持链式表达式。指针
sizeof有两种用法:code
sizeof(object),对对象进行sizeof,也能够写成sizeof object,从这个能够看出,sizeof不多是一个函数,由于没有哪一个函数传参数是不须要括号的对象
sizeof(typename)内存
若是要用sizeof求的复合型类型,如union,struct,class,的对齐方式为成员中对齐方式最大的成员的对齐方式。编译器
易错点:it
q:定义一个空类型,里面没有任何成员变量和成员函数,对该类型求sizeof,获得的结果是什么?io
a:答案为1。由于空类型的实例中不包含任何信息,原本求sizeof应该是0,可是当咱们申明该实例的时候它必须在内存中包含必定的空间,不然没法使用这些实例。至于占用多少内存,由编译器决定,vs2010每一个空类型的实例占用1字节的空间。编译
若是在这个类型中添加一个构造函数和析构函数,再对该类型求sizeof,获得的结果又是多少?class
a:仍是1,由于调用构造函数和析构函数只需知道函数的地址便可,而这些函数的地址只与类型有关,而与类型的实例无关,编译器也不会由于这两个函数而在实例内添加任何额外的信息。
q:若是把析构函数标记为虚函数呢?
a:C++编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每个实例中添加一个指向虚函数表的指针,32bit是4,64bit是8