C++ STL——hash/unordered_set/c++11关键字decltype

本文主要介绍了C++ STL中的hash类模板和unordered_set类模板,包括它们的定义、作用以及如何使用。通过示例代码展示了如何创建和操作unordered_set,并解释了hash函数的作用和find()、equal_range()等方法的功能。同时,文中还探讨了C++11关键字decltype在函数模板中的应用。
摘要由CSDN通过智能技术生成

摘自MSDN,以VS2012版为主


1、hash类模板

定义如下:

[cpp]  view plain   copy
  在CODE上查看代码片 派生到我的代码片
  1. template<class Ty>  
  2.     struct hash  
  3.         : public unary_function<Ty, size_t> {  
  4.     size_t operator()(Ty _Val) const;  
  5.     };  

并给出一个例子:

[cpp]  view plain   copy
  在CODE上查看代码片 派生到我的代码片
  1. // std_tr1__functional__hash.cpp   
  2. // compile with: /EHsc   
  3. #include <functional>   
  4. #include <iostream>   
  5. #include <unordered_set>   
  6.    
  7. int main()   
  8.     {   
  9.     std::unordered_set<int, std::hash<int> > c0;   
  10.     c0.insert(3);   
  11.     std::cout << *c0.find(3) << std::endl;   
  12.    
  13.     return (0);   
  14.     }   
  15.    
输出结果3


2.unordered_set类模板

定义:

[cpp]  view plain   copy
  在CODE上查看代码片 派生到我的代码片
  1. template<class Key,  
  2.     class Hash = std::hash<Key>,  
  3.     class Pred = std::equal_to<Key>,  
  4.     class Alloc = std::allocator<Key> >  
  5.     class unordered_set;  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值