我使用示例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;
Observer.h
#include "types.h"
template <class T>
class Observer
{
public:
Observer(){}
virtual ~Observer() {}
virtual void update(T subject) = 0;
};
Subject.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()) );
}
};
答案 0 :(得分:1)
根据您想要实现的目标,您可以尝试更改(警告,未经测试的代码!):
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;
答案 1 :(得分:1)
pBar
指向Bar
个实例,因此当您通过attach()
时,Observer<BarPtr>
需要shared_ptr<Observer<BarPtr> >
。
(顺便说一句,如果你已经使用过boost,那么Boost.Signals2会不会更好?)