C++模板化的主题观察者继承/角色冲突

C++ Templated Subject Observer Inheritance/Cast Conflict

本文关键字:继承 观察者 角色 冲突 C++      更新时间:2023-10-16

我使用的是这个例子http://www.codeproject.com/Articles/3267/Implementing-a-Subject-Observer-pattern-with-templ以实现模板化的主题/观察者模式。然而,我遇到了一些烦人的编译错误,看起来继承不起作用,或者是一个奇怪的强制转换。任何帮助都会很棒。帖子的底部是引发问题的一行。

错误

FooManager.h: In member function
    'ReturnEnum FooManager::AddBar(BarPtr)':
Foo.h:150: error: no matching function for call to
    'Bar::attach(FooManagerPtr)'
Subject.h:23: note: candidates are: 
    void Subject<T>::attach(Observer<T>) [with T = boost::shared_ptr<Bar>]

代码

types.h

class Bar;
typedef boost::shared_ptr<Bar> BarPtr;
class FooManager;
typedef boost::shared_ptr<FooManager> FooManagerPtr;

观察员.h

#include "types.h"
template <class T>
class Observer
{
    public:
        Observer(){}
        virtual ~Observer() {}
        virtual void update(T subject) = 0;
};

主题h

#include "types.h"
template <class T>
class Subject
{
    private:
        vector< Observer<T> > m_observers;
    public:
        Subject() {}
        virtual ~Subject() {}
        void attach(Observer<T> observer)
        {
            m_observers.push_back(observer);
        }
        void notify()
        {
            for(vector< Observer<T> >::iterator it = m_observers.begin(); it != m_observers.end(); ++it)
            {
                (*it)->update(static_cast<T>(this));
            }
        }
};

Bar.h

#include "types.h"
class Bar             : public Subject<BarPtr>
{
};

FooManager.h

#include "types.h"
class FooManager                : public Observer<BarPtr>
{
    public:
        ReturnEnum AddBar(BarPtr pBar)
        {
            pBar->attach( FooManagerPtr(this, boost_null_deleter()) );
        }
};

根据您想要实现的目标,您可以尝试更改(警告,未经测试的代码!):

    void attach(Observer<T> observer)
    {
        m_observers.push_back(observer);
    }

    void attach(boost::shared_ptr<Observer<T>> observer)
    {
        m_observers.push_back(observer);
    }

vector< Observer<T> > m_observers;

vector< boost::shared_ptr<Observer<T> > > m_observers;

pBar指向Bar实例,因此attach()期望Observer<BarPtr>,而您传递shared_ptr<Observer<BarPtr> >

(顺便说一句,如果你已经使用boost了,那么使用boost.Signals2不是更好吗?)