由于卡片的种类非常的多(100+),为了对每种类型的卡片调用相应的处理函数,定义了一个如下的函数模板:
template<typename T, size_t offset>
int AddCard(const char * pszCardStr, void* base)
{
……
}
可问题是怎么获得每个实例化后的模板函数的指针?查阅了大半天的资料,终于找到了一种可行的办法:
定义一个函数指针:
int (*FuncPtr)(const char*, void* );
FuncPtr = &AddCard<CardClassName, offset constants>;
typedef std::map<const string, FuncPtr> CardTypeStrToProcessorMap;
CardTypeStrToProcessorMap m_TypeProcessorMap;
typedef CardTypeStrToProcessorMap ::value_type VT;
TypeProcessorMap.insert(VT(string(typestring), FuncPtr));
原来出现问题主要有几个地方:
1. 把typedef CardTypeStrToProcessorMap ::value_type VT;误写为
CardTypeStrToProcessorMap ::value_type VT;,结果老提示出错。
2.下面的一步到位的写法编译不过:
TypeProcessorMap.insert(VT(string(typestring), const offset expression));
另外,如果用VC6,似乎不支持带显式模板参数的函数模板实例化。
template<typename T, size_t offset>
int AddCard(const char * pszCardStr, void* base)
{
……
}
可问题是怎么获得每个实例化后的模板函数的指针?查阅了大半天的资料,终于找到了一种可行的办法:
定义一个函数指针:
int (*FuncPtr)(const char*, void* );
FuncPtr = &AddCard<CardClassName, offset constants>;
typedef std::map<const string, FuncPtr> CardTypeStrToProcessorMap;
CardTypeStrToProcessorMap m_TypeProcessorMap;
typedef CardTypeStrToProcessorMap ::value_type VT;
TypeProcessorMap.insert(VT(string(typestring), FuncPtr));
原来出现问题主要有几个地方:
1. 把typedef CardTypeStrToProcessorMap ::value_type VT;误写为
CardTypeStrToProcessorMap ::value_type VT;,结果老提示出错。
2.下面的一步到位的写法编译不过:
TypeProcessorMap.insert(VT(string(typestring), const offset expression));
另外,如果用VC6,似乎不支持带显式模板参数的函数模板实例化。
1772

被折叠的 条评论
为什么被折叠?



