我们有如下内存结构,派生类指针pB和基类指针pA都指向相同的位置,也就是数据c所在的位置。 如果基类有虚函数,也就是如下面代码所示的情况 #include <stdio.h> class A { public: char c; int i; virtual char getChar() const { return c; } }; class B: public A { public: int j; }; int main(...
当然,后面的话进行了强制转换,虽然可以编译成功,但实际上将派生类指针指向基类是不安全的。 因为基类中定义了 ToString()函数,直接通过ptr->ToString()调用是合法的,而在执行ptr->Area()时,虽然没有语法错误,严格来说会产生一个运行是错误 (不过执行时没有报错,不知道为啥)。 在调用 ToString()函数时,调用了基...
基类指针可以new派生类对象,因为派生类对象含有基类部分,所以我们可以把派生类对象当成基类对象来用;编译器内部做了隐式的派生类到基类的转换;这种转换的好处是有些需要用到基类引用/指针地方,可以用这个派生类对象的引用/指针来代替; 派生类构造函数 派生类实际使用基类的构造函数来初始化它的基类部分;基类控制基类部...
Press any key to continue 从输出结果我们可看出,CDerived对象的起始地址存放的是虚表指针vptr,接下来的是基类的成员变量,接下来再是自身的成员变量。
在派生类有同名函数的情况下 Point * pPoint; // 声明的基类指针只能指向基类 Circle * pCircle // 声明的派生类指针只能指向派生类 如果派生类没有基类的同名函数, 派生类的指针才根据继承原则调用基类的函数 虚函数 一旦定义了虚函数, 该基类的派生类中的同名函数也自动成为虚函数. ...
C++与C的另一个区别是,C++可以把派生类对象的地址赋给基类指针,但是在C中没有这里涉及的特性。 8、布尔类型 在C++中,布尔类型是bool,而且ture和false都是关键字。在C中,布尔类型是_Bool,但是要包含stdbool.h头文件才可以使用bool、true和false。 9、可选拼写 ...
首先,基类指针是一个指向基类对象的指针,而派生类是从基类派生出来的一个子类。在C++中,可以将基类指针指向派生类的对象,这种操作被称为“向上转型”。 以下是一个简单的示例,说明如何在目标c中将基类指针指向派生类: 代码语言:cpp 复制 #include<iostream> class Base { public: void print() { std::cout <...
在C++中,基类指针可以指向派生类对象的原因主要包括:多态性体现、内存布局兼容、类型安全和开闭原则。这种特性是C++支持面向对象编程(OOP)的一个关键方面,它允许使用基类类型的指针或引用来操作派生类对象,从而实现代码的通用性和可扩展性。 详细来说,多态性体现是这一特性的核心。多态性允许我们通过基类指针调用那些在...
指向void的指针 C++可以把任意类型的指针赋给指向void的指针,这点与C相同。但是不同的是,只有使用显式强制类型转换才能把指向void的指针赋给其他类型的指针。下面的代码说明了这一点: C++与C的另一个区别是,C++可以把派生类对象的地址赋给基类指针,但是在C中没有这里涉及的特性。
首先析构函数可以为虚函数,当析构一个指向派生类的基类指针时,最好将基类的析构函数声明为虚函数,否则可以存在内存泄露的问题。 如果析构函数不被声明成虚函数,则编译器实施静态绑定,在删除指向派生类的基类指针时,只会调用基类的析构函数而不调用派生类析构函数,这样就会造成派生类对象析构不完全。