【发布时间】:2018-08-26 16:33:32
【问题描述】:
我正在尝试开发基于事件的状态机几个小时,但我无法确定为什么下面的模板类不匹配。
基本上,State 发布事件,StateMachine 监听它们。这是一个sn-p:
#include <iostream>
#include <vector>
// Interface for event listening
template <typename Event, typename Sender>
class EventListener
{
public:
virtual ~EventListener() = default;
virtual void onEvent(const Sender* sender, const Event& data) = 0;
};
// Abstract class for event publishing
template <typename Event>
class EventPublisher
{
public:
typedef EventListener<Event, EventPublisher> Listener;
virtual ~EventPublisher() = default;
// Queues an event listener
void attach(Listener* listener) {
listeners.push_back(listener);
}
protected:
// Publishes an event among all registered listeners
void publish(const Event& e) {
for (Listener* listener : listeners) {
listener->onEvent(this, e);
}
}
private:
std::vector<Listener*> listeners;
};
// Concrete publisher & listener
class StateEvent {};
class StateEventPublisher : public EventPublisher<StateEvent> {};
class StateEventListener : public EventListener<StateEvent, StateEventPublisher> {};
class State : public StateEventPublisher {
public:
void foo() {
publish(StateEvent());
}
};
class StateMachine final : public StateEventListener {
private:
void onEvent(const StateEventPublisher* sender, const StateEvent& e) override {}
};
int main()
{
State state;
StateMachine machine; // Is a StateEventListener, which is a EventListener<StateEvent, StateEventPublisher>, whereas StateEventPublisher is a EventPublisher<StateEvent>
state.attach(&machine); // Incompatible with EventListener<StateEvent, EventPublisher<StateEvent>>*
state.foo();
return 0;
}
如果机器是StateEventListener,即EventListener<StateEvent, StateEventPublisher>,而StateEventPublisher 是EventPublisher<StateEvent>,为什么机器不能附加到状态?!我做错了什么?!
【问题讨论】:
-
用
using StateEventPublisher = EventPublisher<StateEvent>;编译。 -
不确定我是否遗漏了什么,但我没有看到
Listener在任何地方定义。 -
@GillBates
typedef EventListener<Event, EventPublisher> Listener; -
是的,鉴于
struct A{};和struct B: A{}和template<typename T> struct C{}类型C<A>和C<B>是不同且不相关的
标签: c++ c++11 templates inheritance observer-pattern