基类指针指向派生类对象与派生类指针指向基类对象的区别
时间: 2023-05-04 18:01:11 浏览: 142
基本指针指向派生类对象与派生类指针指向基本类对象的区别在于对象的实际类型和指针所指向的类型不同。基本指针只能够访问基类的成员,而派生指针能够访问派生类和基类的成员。需要注意的是,使用派生指针访问基类成员时需要使用强制类型转换。
相关问题
基类指针指向派生类对象和派生类指针指向基类
基类指针是指向基类类型的变量,它可以存储基类的对象引用。当基类指针指向派生类的对象时,由于向下兼容性,这个指针可以成功地访问基类中公共或保护的数据成员,以及覆盖的虚函数。然而,它无法访问派生类特有的私有数据成员。
相反,派生类指针是专门用于存储派生类对象的,它可以直接操作派生类的所有成员,包括基类和派生类新增的部分。因此,派生类指针不仅可以访问基类的方法,还可以访问派生类的特有方法和数据。
举个例子:
```cpp
class Base {
public:
void baseMethod() { cout << "Base method" << endl; }
private:
int privateBaseData;
};
class Derived : public Base {
public:
void derivedMethod() { cout << "Derived method" << endl; }
// 新增的私有数据
int derivedPrivateData;
};
// 基类指针示例
Base* basePtr = new Derived(); // 这样做允许通过basePtr调用Derived的方法
basePtr->baseMethod(); // 输出:"Base method"
// 但是不能访问Derived特有的私有数据
// 派生类指针示例
Derived* derivedPtr = new Derived();
derivedPtr->baseMethod(); // 输出:"Base method"
derivedPtr->derivedMethod(); // 输出:"Derived method"
derivedPtr->derivedPrivateData; // 可以直接访问派生类的私有数据
```
基类指针指向派生类对象的例子
假设我们有一个基类Animal和两个派生类Dog和Cat:
```c++
class Animal {
public:
virtual void makeSound() {
cout << "Animal sound" << endl;
}
};
class Dog : public Animal {
public:
void makeSound() override {
cout << "Bark" << endl;
}
};
class Cat : public Animal {
public:
void makeSound() override {
cout << "Meow" << endl;
}
};
```
现在,我们可以创建一个指向Dog对象和一个指向Cat对象的基类指针:
```c++
Animal* animal1 = new Dog();
Animal* animal2 = new Cat();
```
这些指针都指向派生类的对象。我们可以调用它们的虚函数`makeSound()`:
```c++
animal1->makeSound(); // 输出 "Bark"
animal2->makeSound(); // 输出 "Meow"
```
由于`makeSound()`是一个虚函数,编译器会在运行时确定要调用哪个版本的函数,即使它们都在基类中定义。这就是多态的概念。在这个例子中,基类指针`animal1`和`animal2`指向的是不同的对象,但它们都可以调用基类中的`makeSound()`函数以及派生类中的重载版本。
阅读全文