首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用基类指针查找派生类对象的大小

在C++中,使用基类指针查找派生类对象的大小是不可行的。因为基类指针不能直接访问派生类对象的大小,因为它不包含派生类对象的信息。

如果您想要查找派生类对象的大小,您可以使用以下方法之一:

  1. 使用 sizeof 运算符:sizeof(派生类对象) 将返回派生类对象的大小。
  2. 使用虚函数:在基类中添加一个虚函数,如 virtual size_t getSize() const = 0;,然后在派生类中重写该函数,返回派生类对象的大小。

例如:

代码语言:cpp
复制
class Base {
public:
    virtual size_t getSize() const = 0;
};

class Derived : public Base {
public:
    virtual size_t getSize() const {
        return sizeof(Derived);
    }
};

int main() {
    Base* basePtr = new Derived();
    size_t derivedSize = basePtr->getSize();
    delete basePtr;
    return 0;
}

在这个例子中,getSize() 函数在基类中声明为虚函数,并在派生类中重写,以便返回派生类对象的大小。通过使用基类指针 basePtr,我们可以调用 getSize() 函数来获取派生类对象的大小。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • C++中派生类对基类成员的访问形式

    C++中派生类对基类成员的访问形式主要有以下两种: 1、内部访问:由派生类中新增成员对基类继承来的成员的访问。 2、对象访问:在派生类外部,通过派生类的对象对从基类继承来的成员的访问。...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类的成员还是通过派生类的对象,都无法直接访问从基类继承来的private成员,但是可以通过基类提供的public成员函数间接访问。...但是,类的外部使用者只能通过派生类的对象访问继承来的public成员。... 当类的继承方式为保护继承时,基类的public成员和protected成员被继承到派生类中都作为派生类的protected成员,派生类的其它成员可以直接访问它们,但是类的外部使用者不能通过派生类的对象访问它们...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类成员还是通过派生类的对象,都无法直接访问基类中的private成员。

    2.4K70

    派生类对基类中虚函数和非虚函数的继承效果

    ,这里是Animal指针指向,所以他就调用Animal里面的,普通函数是父类为子类提供的“强制实现”,也就是只要是父类指针调用普通函数,那就是父类的普通函数 而虚函数的作用,主要是为了让父类指针可以调用子类的函数...,这种是在运行时才决定调用哪个函数 1、虚函数:   C++的虚函数主要作用是“运行时多态”,父类中提供虚函数的实现,为子类提供默认的函数实现。...子类可以重写父类的虚函数实现子类的特殊化。 2、纯虚函数:   C++中包含纯虚函数的类,被称为是“抽象类”。抽象类不能使用new出对象,只有实现了这个纯虚函数的子类才能new出对象。   ...3、普通函数:   普通函数是静态编译的,没有运行时多态,只会根据指针或引用的“字面值”类对象,调用自己的普通函数。   普通函数是父类为子类提供的“强制实现”。   ...因此,在继承关系中,子类不应该重写父类的普通函数,因为函数的调用至于类对象的字面值有关。 参考链接

    9210

    C++:43---派生类向基类转换、静态动态的类变量

    此时基类可以通过指针或引用指向派生类(相当于将派生类从基类中继承的那部分方法和成员绑定到基类上了,相当于派生类被截断了),然后基类就可以将派生类假装是一个基类对象来使用(调用其中的成员/方法) ②为什么基类不能转换为派生类...如果将一个基类对象绑定到派生类的指针/引用上,此时派生类通过指针/引用访问自己新定义的成员/方法时,发现找不到(因此不能将基类转换为派生类) 例如:下面B继承于A,子类继承于父类,同时为父类的成员开辟了空间...三、继承方式对类型转换的影响 遵循下面3个规则: 假设B继承于A ①只有当B公有地继承A时,用户代码才能使用派生类向基类转换;如果B是受保护的/私有的继承于A,则不能使用派生类向基类转换 因为保护或者私有继承...,因为其只能与自己类型一致的对象绑定到一起 演示案例 当我们使用基类的引用(或指针)时,我们并不清楚该引用(或指针)所绑定的对象的真实类型,该对象可能是基类的对象,也可能是派生类的对象。...函数 打印“B:show2”:因为show2()函数为虚函数,所以根据虚函数的性质,使用基类的指针访问子类时,访问虚函数跟指针所指的类对象类型有关,此处指针所指的类类型为B,因此访问B的show2()函数

    1.8K10

    PHP面向对象-继承和派生类的定义(一)

    继承的定义继承是一种面向对象编程机制,它允许一个新的类从现有的类中继承属性和方法。在继承中,现有的类称为父类或超类,新的类称为子类或派生类。...子类继承了父类的属性和方法,并且可以添加自己的属性和方法,或者覆盖继承的方法。在PHP中,使用extends关键字实现类的继承。...在上面的示例中,我们定义了一个Animal类,它有一个name属性和一个speak()方法。然后我们定义了一个Dog类,它继承了Animal类,并添加了一个bark()方法。...我们创建了一个Dog对象,并设置了name属性为Fido,然后调用了Dog对象的speak()和bark()方法。在Dog类中,我们使用extends关键字来指定Animal类作为父类。...子类继承了父类的name属性和speak()方法,可以直接使用它们。子类还添加了一个新的bark()方法,它是子类自己的方法。

    43220

    【c++】类和对象(上)(类的定义格式、访问限定符、类域、类的实例化、对象的内存大小、this指针)

    面向对象编程是一种编程范式,它使用“类”来定义对象的属性和方法,完成对软件的设计。掌握类和对象的概念及其相互关系,对于深入理解并有效应用面向对象编程至关重要。...因为类域影响的是编译器的查找规则。如果fun函数没有声明类域,那么编译器就会从全局域去查找该函数的声明。此时如果fun函数有涉及对成员变量_m的操作,编译器从全局域找不到_m,就会发生报错。...对象的内存大小 既然创建对象时才分配内存空间,那么对象所占内存空间的大小是多少呢?...在函数的实参和形参中,这个this指针会自动在参数第一个位置生成,我们不能显示地写出来;但是在函数体内我们可以使用this指针。 2. this指针只能在成员函数内部使用。...原因是:这里创建类指针a,并且调用函数Print。可以看到程序中虽然使用了“->”,但是并没有对空指针a进行解引用,本质是将a传递给了形参this指针。

    18810

    后台开发:核心技术与应用实践 -- C++

    同时,无论哪一种继承方式,在派生类中是不能访问基类的私有 成员的,私有成员只能被本类的成员函数所访问,毕竟派生类与基类不是同一个类 构造派生类的对象时,必须对基类数据成员、新增数据成员和成员对象的数据成员进行初始化...派生类构造函数必须对这3类成员进行初始化,其执行顺序是这样的: 先调用基类构造函数; 再调用子对象的构造函数; 最后调用派生类的构造函数体 当派生类有多个基类时,处于同一层次的各个基类的构造函数的调用顺序取决于定义派生类时声明的顺序...在执行派生类的析构函数时,系统会自动调用基类的析构函数和子对象的析构函数,对基类和子对象进行清理。...而 虚函数 的作用是允许在派生类中重新定义与基类同名的函数,并且可以通过基类指针或引用来访问基类和派生类中的同名函数。...虚函数的声明方式: virtual 返回类型 函数名(); 当把基类某个成员函数声明为虚函数后,就允许在其派生类中对该函数重新定义,赋予它新的功能,且可以通过指向基类的指针指向同一类族中不同类的对象,从而调用其中的同名函数

    1.3K10

    掌握了多态的特性,写英雄联盟的代码更少啦!

    「派生类的指针」可以赋给「基类指针」; 通过基类指针调用基类和派生类中的同名「虚函数」时: 若该指针指向一个基类的对象,那么被调用是 基类的虚函数; 若该指针指向一个派生类的对象,那么被调用 的是派生类的虚函数...— — || 03 多态的表现形式二 派生类的对象可以赋给基类「引用」 通过基类引用调用基类和派生类中的同名「虚函数」时: 若该引用引用的是一个基类的对象,那么被调 用是基类的虚函数; 若该引用引用的是一个派生类的对象...多态的函数调用语句被编译成一系列根据基类指针所指向的(或基类引用所引用的)对象中存放的虚函数表的地址,在虚函数表中查找虚函数地址,并调用虚函数的指令。...那么在多态的情景下,通过基类的指针删除派生类对象时,通常情况下只调用基类的析构函数,这就会存在派生类对象的析构函数没有调用到,存在资源泄露的情况。...解决办法:把基类的析构函数声明为virtual 派生类的析构函数可以 virtual 不进行声明; 通过基类的指针删除派生类对象时,首先调用派生类的析构函数,然后调用基类的析构函数,还是遵循「先构造,后虚构

    53010

    再探虚函数

    函数模板的使用 动态多态 在基类的函数前加上virtual关键字,在派生类中重写该函数,运行时将会根据所指对象的实际类型来调用相应的函数,如果对象类型是派生类,就调用派生类的函数,如果对象类型是基类,...如果说,抽象类无法实例化对象,那就无法使用对象方法了嘛。...只有在基类析构函数定义为虚函数时,调用操作符delete销毁指向对象的基类指针时,才能准确调用派生类的析构函数(从该级向上按序调用虚函数),才能准确销毁数据。...3、虚函数表存储虚函数的地址,即虚函数表的元素是指向类成员函数的指针,而类中虚函数的个数在编译时期可以确定,即虚函数表的大小可以确定,即大小是在编译时期确定的,不必动态分配内存空间存储虚函数表。...多态的函数调用语句被编译成根据基类指针所指向的(或基类引用所引用的)对象中存放的虚函数表的地址,在虚函数表中查找虚函数地址,并调用虚函数的一系列指令。

    87620

    十一、多态

    即,需要使用基类类型的指针或引用来指向子类对象,并通过该指针或引用来调用虚函数。 原理:在运行时,程序会根据指针或引用所指向对象的实际类型,在虚函数表中查找并调用相应的函数版本。...多态的意义 提高代码的复用性和可扩展性: 多态允许使用基类类型的指针或引用来引用派生类的对象,这样就可以通过基类指针或引用来调用派生类中的方法,而无需知道具体的派生类类型。...通过在基类中将函数声明为virtual,我们可以实现多态,即使用基类类型的指针或引用来调用派生类中的成员函数。...这可能导致资源泄漏或未定义行为,因为派生类可能分配了需要手动释放的资源(如动态分配的内存、文件句柄等)。 使用场景: 当通过基类指针删除派生类对象时,确保派生类的析构函数被调用。...注意事项 虚函数表指针是编译器实现的一部分,标准C++并没有直接暴露这个指针。 虚函数表指针的存在增加了对象的大小(通常是4或8字节,取决于指针的大小)。

    10110

    深入浅出C++虚函数的vptr与vtable

    深入浅出C++虚函数的vptr与vtable 1.基础理论 为了实现虚函数,C ++使用一种称为虚拟表的特殊形式的后期绑定。该虚拟表是用于解决在动态/后期绑定方式的函数调用函数的查找表。...首先,每个使用虚函数的类(或者从使用虚函数的类派生)都有自己的虚拟表。该表只是编译器在编译时设置的静态数组。虚拟表包含可由类的对象调用的每个虚函数的一个条目。...与this指针不同,this指针实际上是编译器用来解析自引用的函数参数,vptr是一个真正的指针。 因此,它使每个类对象的分配大一个指针的大小。这也意味着vptr由派生类继承,这很重要。...Base &pp = ptr; // 基类引用指向基类实例 Base &p = d; // 基类引用指向派生类实例 cout基类对象直接调用"<<endl; ptr.fun1...例如,上述通过基类指针指向派生类实例,并调用虚函数,将上述代码简化为: Base *pt = new Derived(); // 基类指针指向派生类实例 cout基类指针指向派生类实例并调用虚函数

    4.4K30

    C++:13---多态和虚函数表

    多态的意思为“以一个public基类的指针/引用,寻址一个派生类对象”。 “多态”的关键在于通过基类指针或引用调用一个虚函数时,编译时不确定到底调用的是基类还是派生类的函数,运行时才确定。...这是如何实现的呢? 请看下面的程序,该程序演示了多态类对象存储空间的大小。...每一个有虚函数的类(或有虚函数的类的派生类)都有一个虚函数表,该类的任何对象中都放着该虚函数表的指针(可以认为这是由编译器自动添加到构造函数中的指令完成的)。...图2:类B对象的存储空间以及虚函数表 多态的函数调用语句被编译成根据基类指针所指向的(或基类引用所引用的)对象中存放的虚函数表的地址,在虚函数表中查找虚函数地址,并调用虚函数的一系列指令。...由以上过程可以看出,只要是通过基类指针或基类引用调用虚函数的语句,就一定是多态的,也一定会执行上面的查表过程,哪怕这个虚函数仅在基类中有,在派生类中没有。

    71820

    指针偏移?多态数组? delete 基类指针 内存泄漏?崩溃?

    ]))(p, arg-list); 其中p是基类指针,vptr是p指向的对象的隐含指针,而slotNum 就是调用的虚函数指针在vtable 的编号,这个数组元素的索引号在编译时就确定下来, 并且不会随着派生层的增加而改变...,取基类指针一定是偏移的。...如果没有这样做的话,只会输出基类的 析构函数,这种输出情况通过比对规则2也可以理解,pI 现在虽然指向派生类对象首地址,但执行pI->~IRectangle() 时 发现不是虚函数,故直接调用, 假如在派生类析构函数内有释放内存资源的操作...因为此时基类是空类1个字节,派生类有虚函数故有vptr 4个字节,基类“继承”的1个字节附在vptr下面,现在的p 实际上是指向了附属1字节,即operator delete(void*) 传递的指针值已经不是...将基类析构函数改成虚函数,fun() 最好也改成虚函数,只要有一个虚函数,基类大小就为一个vptr ,此时基类和派生类大小都是4个字节,p也指向派生类的首地址,问题解决,参考规则3。

    1K20

    从零开始学C++之继承(二):继承与构造函数、派生类到基类的转换

    从输出可以看出: 派生类对象的构造次序: 先调用基类对象成员的构造函数,接着是基类的构造函数,然后是派生类的对象成员的构造函数,最后是派生类自身的构造函数。...四、派生类到基类的转换 当派生类以public方式继承基类时,编译器可自动执行的转换(向上转型 upcasting 安全转换) 派生类对象指针自动转化为基类对象指针 派生类对象引用自动转化为基类对象引用...派生类对象自动转换为基类对象(特有的成员消失) 当派生类以private/protected方式继承基类时 派生类对象指针(引用)转化为基类对象指针(引用)需用强制类型转化。...将派生类对象看成基类对象     //pm = &e1; // 基类对象指针无法转化为派生类对象指针。...; // 基类对象无法强制转化为派生类对象     return 0; } 五、基类到派生类的转换 基类对象指针(引用)可用强制类型转换为派生类对象指针(引用), 而基类对象无法执行这类转换.

    1.5K00

    指针偏移?多态数组? delete 基类指针 内存泄漏?崩溃?

    ]))(p, arg-list); 其中p是基类指针,vptr是p指向的对象的隐含指针,而slotNum 就是调用的虚函数指针在vtable 的编号,这个数组元素的索引号在编译时就确定下来, 并且不会随着派生层的增加而改变...,取基类指针一定是偏移的。...如果没有这样做的话,只会输出基类的 析构函数,这种输出情况通过比对规则2也可以理解,pI 现在虽然指向派生类对象首地址,但执行pI->~IRectangle() 时 发现不是虚函数,故直接调用, 假如在派生类析构函数内有释放内存资源的操作...因为此时基类是空类1个字节,派生类有虚函数故有vptr 4个字节,基类“继承”的1个字节附在vptr下面,现在的p 实际上是指向了附属1字节,即operator delete(void*) 传递的指针值已经不是...将基类析构函数改成虚函数,fun() 最好也改成虚函数,只要有一个虚函数,基类大小就为一个vptr ,此时基类和派生类大小都是4个字节,p也指向派生类的首地址,问题解决,参考规则3。

    98600

    【笔记】《C++Primer》—— 第15章:面向对象程序设计

    有些时候我们不希望派生类独有的部分被截断,则需要使用类指针来调用重载的函数或使用指针所指的成员。...每次继承一个基类就会在内存中生成一个子对象,存放了基类的成员,也正是因为这个原因派生类可以转换为基类。如果是对象转换到对象,那多余的成员会被截断。...为了规范和可读性,最好不要利用默认控制符,显式说明比较清晰 15.6 继承中的类作用域 类中的名字查找是从内到外查找的,当派生类中无法找到时,就会往直接基类查找,以此类推 名称查找是根据编译时的目标的静态类型进行查找的...因此除了重载虚函数外最好不要让名称同名 假如基类和派生类的虚函数形参不同,我们就无法使用基类的引用或指针来动态调用派生类的函数了,此时两个函数将被判断为独立的函数并将外层隐藏。...,对于实现的内容我们一样可以使用=default简化 如果基类的析构函数不是虚函数,则delete一个指向派生类对象的基类指针将产生未定义的行为 如果定义了虚析构函数,则一样的合成移动操作将被阻止 派生类的析构函数和以往一样是空函数

    53320

    「类与对象」如何准确获取对象的内存大小?

    回顾一下对象的本质 在上篇文章「类与对象」揭秘本质的第一步中,揭秘NSObject类的底层数据结构,如下所示: struct NSObject_IMPL { Class isa; }; 在Xcode...class_getInstanceSize 首先,这是一个runtime提供的API,用于获取类实例对象所占用的内存大小,返回所占用的字节数。...终于看到了希望,当实例对象大小不足16个字节,系统分配给16个字节,属于系统的硬性规定。...; 例如:在64位架构下,自定义一个NSObject对象,无论该对象生命多少个成员变量,最后得到的内存大小都是8个字节。...在64位架构下, 系统分配了16个字节给NSObject对象(通过malloc_size函数获得); 但NSObject对象内部只使用了8个字节的空间(可以通过class_getInstanceSize

    4.6K10
    领券