在C++继承中,很容易遇到一个问题,那就是将派生类指针赋值给基类指针(向上转型)的情况,下面我们就来举例分析:
举一个多继承的例子:

#include <iostream>
using namespace std;
//基类A
class A {
public:
A(int a);
public:
void display();
protected:
int m_a;
};
A::A(int a) : m_a(a) { }
void A::display() {
cout << "Class A: m_a=" << m_a << endl;
}
//中间派生类B
class B : public A {
public:
B(int a, int b);
public:
void display();
protected:
int m_b;
};
B::B(int a, int b) : A(a), m_b(b) { }
void B::display() {
cout << "Class B: m_a=" << m_a << ", m_b=" << m_b << endl;
}
//基类C
class C {
public:
C(int c);
public:
void display();
protected:
int m_c;
};
C::C(int c) : m_c(c) { }
void C::display() {
cout << "Class C: m_c=" << m_c << endl;
}
//最终派生类D
class D : public B, public C {
public:
D(int a, int b, int c,

本文探讨了C++中派生类指针赋值给基类指针的情况,通过一个多继承的例子展示了指针转换后的行为。分析指出,基类指针只能访问派生类的成员变量,而不能调用派生类的非虚成员函数,因为编译器基于指针类型而非指向的对象来决定调用哪个类的函数。同时,基类的引用或指针无法访问派生类新增的成员,除非通过虚函数机制。
最低0.47元/天 解锁文章
662

被折叠的 条评论
为什么被折叠?



