使用基类智能指针重载函数

时间:2013-09-12 11:18:34

标签: c++ oop inheritance overloading

我有3个类:第一个是纯虚拟基类base,派生类derived1derived2 ...

第二个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;
}

然而,这似乎失败,错误没有匹配的成员函数。所以我的问题首先是这种方法有明显的错误,其次是更有效/面向对象的设计方法,更好地处理这类问题。

1 个答案:

答案 0 :(得分:0)

原则上这是正确的做法:在基础上调用函数,多态将做正确的事。

但是,你的代码将无法编译:bar中的func定义无效(至少我不确定你的意图是什么 - 它们应该实现什么?)和func调用callfunc两次取消引用指针。

如果您需要具体修复,请提供确切的错误。