在C++模板类map中一个参数为Compare类型,该类型为一个比较函数,其完整定义如下:
template<
class Key,
class T,
class Compare = std::less<Key>,
class Allocator = std::allocator<std::pair<const Key, T> >
> class map;
函数作为类进行传递,该类采用了重载操作符()来实现函数指针到类的转变。在实际中也可以仿照此风格写自己的类。
template <typename Key, typename Value, class Hash >
class A {
Hash hash_fn;
public:
A():hash_fn(Hash()) { } size_t hashCode(Key key) { return hash_fn(key);} };
第三个参数Hash为函数对象,该对象通过重载操作符()来实现,其一个字符串类型的Key定义如下:
struct str_hash {
size_t operator()(const std::string& str) const
{
return ;
}
};
当调用hash_fn(key)函数时,该重载函数被调用,这样就实现了转换。由于C++标准库中包含有大量此类型风格的类,我们就可以通过默认参数来调用标准类,这样上面的模板类A就可以定义如下:
template <typename Key, typename Value, class Hash = std::hash<Key>>
测试程序如下:
int main(int argc, char *argv[]) { A<std::string , int, str_hash> a;
std::cout << "hashCode:" << a.hashCode("abc") << std::endl; A<std::string,int,std::hash<std::string>> h;
std::cout << h.hashCode("abc") << std::endl; A<std::string,int> h2;
std::cout << h.hashCode("abc") << std::endl; return ;
}
测试结果如下:
functiontem
hashCode: