【C++】sizeof
2015-08-03 23:22
393 查看
定义一个空类型,里面没有任何成员变量和成员函数,对该类型求sizeof,得到的结果是多少?
class foo {
;
};
答案是1。
为什么?
空类型的实例中不包含任何信息,本来sizeof的结果应该是0,但当我们声明该类型的实例时,它必须在内存中占有一定的空间,否则无法使用这些实例。
至于占用多少内存,由编译器决定。VS中每个空类型的实例占用1字节的空间。
如果在该类型中添加一个构造函数和析构函数,再对该类型求sizeof,得到的结果又是多少?
class foo {
foo() {;}
~foo() {;}
};
还是1.
调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址只与类型相关,而与类型的实例无关。编译器也不会因为这两个函数而在实例内添加任何额外的信息。
那如果把析构函数标记为虚函数呢?
class foo {
foo() {;}
virtual ~foo() {;}
}
C++的编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每一个实例中添加一个指向虚函数表的指针。
在32位机器上,一个指针占4字节的空间,因此求sizeof的结果为4;如果是64位机器,一个指针占8字节空间,sizeof结果为8。
class foo {
;
};
答案是1。
为什么?
空类型的实例中不包含任何信息,本来sizeof的结果应该是0,但当我们声明该类型的实例时,它必须在内存中占有一定的空间,否则无法使用这些实例。
至于占用多少内存,由编译器决定。VS中每个空类型的实例占用1字节的空间。
如果在该类型中添加一个构造函数和析构函数,再对该类型求sizeof,得到的结果又是多少?
class foo {
foo() {;}
~foo() {;}
};
还是1.
调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址只与类型相关,而与类型的实例无关。编译器也不会因为这两个函数而在实例内添加任何额外的信息。
那如果把析构函数标记为虚函数呢?
class foo {
foo() {;}
virtual ~foo() {;}
}
C++的编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每一个实例中添加一个指向虚函数表的指针。
在32位机器上,一个指针占4字节的空间,因此求sizeof的结果为4;如果是64位机器,一个指针占8字节空间,sizeof结果为8。
相关文章推荐
- c++中的函数 和 c 函数的不同
- 5、C语言和设计模式(之组合模式)
- 4、C语言和设计模式(之原型模式)
- C语言的const与C++const的区别
- 3、C语言和设计模式(之单件模式)
- C++成员变量的初始化顺序问题
- C++运算符 转换
- 10道C++输出易错笔试题收集
- 2、C语言和设计模式(继承、封装、多态)
- 1、C语言和设计模式(之开篇)
- iOS开发分分钟搞定C语言 —— 宏定义和关键字
- C++知识点总结(6)
- C++知识点总结(6)
- C++ 布尔类型bool
- qt c++ bad_alloc
- c++ opencv显示对话框
- c++ opencv显示对话框
- c++ opencv 入门
- c++ opencv 入门
- c++ auto_ptr笔记