C++模板中的函数对象

在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:
上一篇:给TextView添加超链接的四种方式


下一篇:第一个lucene程序,把一个信息写入到索引库中、根据关键词把对象从索引库中提取出来、lucene读写过程分析