我有3个类:第一个是纯虚拟基类base
,派生类derived1
,derived2
...
第二个foo
将智能ptr保存到基类
第三个拥有一个智能ptr到foo
并且有一个重载的成员函数,我想依赖于foo指向的ptr派生类。
这是工作代码
#include<iostream>
#include<boost/shared_ptr.hpp>
using namespace std;
class base{
public:
base(){}
~base(){}
virtual void FuncDer()=0;
};
class derived1 : public base{
derived1(){}
virtual void FuncDer(){
cout<<"derived function1!"<<endl;
}
};
class derived2 : public base{
derived2(){}
virtual void FuncDer(){
cout<<"derived function2!"<<endl;
}
};
class foo {
public:
foo();
~foo();
boost::shared_ptr<base> get_base_ptr(){
return base_obj;
}
private:
boost::shared_ptr<base> base_obj;
};
class bar {
public:
bar();
~bar();
void callfunc(){
func(foo_ptr->get_base_ptr());
}
private:
boost::shared_ptr<foo> foo_ptr;
void func(boost::shared_ptr<derived1>);
void func(boost::shared_ptr<derived2>);
};
int main()
{
cout<<"test"<<endl;
return 0;
}
然而,这似乎失败,错误没有匹配的成员函数。所以我的问题首先是这种方法有明显的错误,其次是更有效/面向对象的设计方法,更好地处理这类问题。
答案 0 :(得分:0)
原则上这是正确的做法:在基础上调用函数,多态将做正确的事。
但是,你的代码将无法编译:bar中的func
定义无效(至少我不确定你的意图是什么 - 它们应该实现什么?)和func调用callfunc
两次取消引用指针。
如果您需要具体修复,请提供确切的错误。