C++中使用基类指针调用派生类中定义的方法
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了。
- C++中使用基类指针调用派生类中定义的方法
- C++ 基类、派生类对象指针的声明与使用
- 在C++中,要实现动态联编,必须使用(基类指针)调用虚函
- C++中基类继承 enable_shared_from_this 之后派生类无法使用 shared_from_this() 的解决方法
- C/C++中为什么在类外利用多态基类指向派生类指针可以调用类的私有成员函数?
- C++基类指针和派生类指针之间的转换方法讲解
- C++ 函数指针的定义方法及使用
- C++基类调用派生类的方法
- C++中通过派生类调用第二基类的普通成员函数时this指针的调整
- [疑问]C/C++中为什么在类外利用多态基类指向派生类指针可以调用类的私有成员函数?
- 关于c++在内存布局意义下使用派生类指针访问基类
- Ruby之旅(二) Ruby的基本语法以及对象的使用,方法的定义及调用,属性的定义及使用
- C++中,函数声明时指针、引用相关的语义,定义方法原型时参考。
- struts2教程:10、动态方法调用和使用通配符定义action
- C++基类、派生类构造函数调用顺序
- C#调用C++方法,C#使用c++方法返回类或结构体
- C++中使用Lua脚本 和lua中调用c的方法
- 使用纯C函数指针调用C++的类成员函数
- 派生类指针方法获取基类的函数
- C++指针使用方法解惑 (待阅)