如何在具有不同命名空间的派生c++类中初始化模板静态成员
How to initialize template static member in derived C++ class with different namespaces
我有以下基类:
namespace n1 {
template <class T, typename A>
class FSM
{
protected:
typedef void (T::*pfun)();
typedef std::map<A, pfun > transition_table_t;
static transition_table_t _transition_table;
};
} // namespace n1
和以下一组宏,用于定义派生类字段
中的静态成员#define BEGIN_TRANSITION_MAP(class_type, state_type)
template <> std::map< state_type, class_type::*pfun > FSM<class_type, state_type>::_transition_table= {
#define TRANSITION_ENTRY(state, action)
{state, action},
#define END_TRANSITION_MAP
};
现在,在另一个cpp
文件中,我定义了下一个派生类:
namespace n1{
namespace n2{
namespace n3{
enum state{
state1,
state2,
};
class derive : public FSM<derive, state>
{
friend class FSM<derive, state>;
void event_a();
void event_b();
};
BEGIN_TRANSITION_MAP(n2::n3::derive, n2::n3::state)
TRANSITION_ENTRY(n2::n3::state1, &n2::n3::derive::event_a)
TRANSITION_ENTRY(n2::n3::state2, &n2::n3::derive::event_b)
END_TRANSITION_MAP
}//namespace n3
}//namespace n2
}//namespace n1
此代码在g++ 4.7
和c++11
下可以正常编译。
我想编写相同的内容,但不需要在派生类中执行基类friend
,也不需要在宏中指定所有名称空间。比如:
namespace n1{
namespace n2{
namespace n3{
enum state{
state1,
state2,
};
class derive : public FSM<derive, state>
{
void event_a();
void event_b();
};
BEGIN_TRANSITION_MAP(derive, state)
TRANSITION_ENTRY(state1, &derive::event_a)
TRANSITION_ENTRY(state2,&derive::event_a)
END_TRANSITION_MAP
} //namespace n3
} //namespace n2
} //namespace n1
这是可能的,还是有更好的方法来解决这个问题?
仅在派生类中定义转换表。然后使用derived::transition_table从基类引用它。这就是所谓的奇怪循环模板模式(谷歌一下)。
template <typename derived>
class FSM
{
public:
typedef std::map<state_type, event_type> transition_table_t;
// do not define transition_table here
void function()
{
// use transition table of derived type
derived::transition_table.do_something();
}
};
class Derived : public FSM<Derived>
{
public:
static transition_table_t transition_table;
};
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员