定义一个空的类型,里面没有任何成员变量和成员函数,对该类型求sizeof,得到的结果是多少?
答案是1
为什么不是?
空类型的实例中不包含任何信息,本来求sizeof应该是,但是当我们声明该类型的实例的时候,它必须在内存中占有一定的空间,否则无法使用这些实例。至于占用躲闪内存,有编译器决定,Visual Studio中每个空类型的实例占用1字节的空间
如果在该类型中添加一个构造函数和析构函数,再对该类型求sizeof,得到的结果又是多少?
和前面一样,还是1,调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址和类型相关,而与类型的实例无关,编译器也不会因为这两个函数而在实例内添加任何额外的信息。
那如果把析构函数标记为虚函数呢?
C++的编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每一个实例中添加一个指向虚函数表的指针。在张着位的机器上,一个指针占用字节的空间。如果是长位的机器,一个指针占个字节的空间。
答案是1
为什么不是?
空类型的实例中不包含任何信息,本来求sizeof应该是,但是当我们声明该类型的实例的时候,它必须在内存中占有一定的空间,否则无法使用这些实例。至于占用躲闪内存,有编译器决定,Visual Studio中每个空类型的实例占用1字节的空间
如果在该类型中添加一个构造函数和析构函数,再对该类型求sizeof,得到的结果又是多少?
和前面一样,还是1,调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址和类型相关,而与类型的实例无关,编译器也不会因为这两个函数而在实例内添加任何额外的信息。
那如果把析构函数标记为虚函数呢?
C++的编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并在该类型的每一个实例中添加一个指向虚函数表的指针。在张着位的机器上,一个指针占用字节的空间。如果是长位的机器,一个指针占个字节的空间。