C++中使用基类指针调用派生类中定义的方法
问题提出
假设有这样一段代码:
class.h:
class A {
public:
A();
public:
virtual void run() = 0;
};
class B : public A {
public:
B();
public:
void run();
void func();
private:
int pri_value;
};
class.cpp:
A::A(){
cout << "class A" << endl;
}
B::B(){
cout << "class B" << endl;
}
void B::run(){
cout << "run()" << endl;
cout << pri_value << endl;
}
void B::func(){
cout << "func()" << endl;
pri_value = 100;
}
main.cpp:
int main(){
A *p = new B;
p->run();
p->func();
p->run();
}
这里class A是一个虚基类,class B是由classA派生来的类,在class B中又定义了一个基类中没有的方法func()。
在主函数中,通过A类型的指针调用B类型的方法func()时会报错:
main.cpp:10:8: error: ‘class A’ has no member named ‘func’ p->func();
这是因为p是A的指针,编译器傻傻的在A的代码空间中找func这个方法,自然找不到。
解决方法
编译器既然这样笨,就得靠聪明的我们来告诉他这个指针其实指向了class B的代码空间,可以在里面找到func()方法。c++提供了一个运算符来让我们告诉编译器如何转换,就是dynamic_cast。下面就是讲class A*强制转换为class B*的方法:
class B* pt = dynamic_cast<B*>(p);
所以为了解决上面的问题,可以将main.cpp改写如下:
int main(){
A *p = new B;
dynamic_cast<B*>(p)->func(); // cast A* to B*
p->func();
p->run();
}
这样编译器就能找到func了。