我正在使用示例 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>]
代码
类型.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));
}
}
};
酒吧.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;
关于C++ 模板化主题观察者继承/转换冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11507802/