Template的作用是把仅类型不同但功能相似的函数合并在一起,但是有时候template中的函数并不能满足所有的类型调用。如下所示:
template <class Kty>
inline int hash_wrap(const Kty& k)
{
return (int)k;
}
所有的数字类型使用该模板都没有问题,但是string类型却不行,因为不支持有string到int的类型转换(编译过程中)。这样我们就要在该模板外添加一个对string类型的支持,可以这么写。
template <>
inline int hash_wrap<string>(conststring & k)
{
return k.size();
}
我理解‘template <>’表明该函数还是模板类型的延伸,‘<string>’表明对原模板的该string类型进行改写。
另举两个例子如下所示:
template <class Kty>
inline unsigned int get_size(const Kty&k)
{
return sizeof(Kty);
}
template <>
inline unsigned int get_size(conststring& k)
{
return k.length() + 1;
}
template <class Kty>
inline bool cmp_key(const Kty& k, constchar* dest)
{
return k == *(Kty* )dest;;
}
template <>
inline bool cmp_key(const string& k,const char* dest)
{
return strcmp(k.c_str(), dest) == 0;
}