STL源码剖析 [容器](十九)[stl_hash_fun.h]
来源:互联网 发布:开票软件自动更新多久 编辑:程序博客网 时间:2024/06/04 08:08
hash表的实现是采用拉链法,其中用到了哈希函数,哈希函数的作用是把元素键值映射到对应的桶子里面,一般哈希值是键值对桶子数取余。
源码:
#ifndef __SGI_STL_HASH_FUN_H#define __SGI_STL_HASH_FUN_H#include <stddef.h>__STL_BEGIN_NAMESPACE//hash function 是计算元素位置的函数//这些函数可以对hashtable进行取模运算//这是hashtable所提供的散列函数是取模运算决定的/*SGI hashtable以下有限的定义类型:struct hash<char*>struct hash<const char*>struct hash<char> struct hash<unsigned char> struct hash<signed char>struct hash<short>struct hash<unsigned short> struct hash<int> struct hash<unsigned int>struct hash<long> struct hash<unsigned long>不在这里定义的类型,不能使用,若用户想要使用,则必须自己定义。例如:string,double,float*//*定义自己的哈希函数时要注意以下几点:[1]使用struct,然后重载operator().[2]返回是size_t[3]参数是你要hash的key的类型。[4]函数是const类型的。*/template <class _Key> struct hash { };//对const char* 提供字符串转换函数inline size_t __stl_hash_string(const char* __s){ unsigned long __h = 0; for ( ; *__s; ++__s) __h = 5*__h + *__s; return size_t(__h);}__STL_TEMPLATE_NULL struct hash<char*>{ size_t operator()(const char* __s) const { return __stl_hash_string(__s); }};__STL_TEMPLATE_NULL struct hash<const char*>{ size_t operator()(const char* __s) const { return __stl_hash_string(__s); }};//下面的hash函数都是直接返回原值//对于char,unsigned char,signed char,int,unsigned int, //short, unsigned short, long,unsigned long都只是返回数值本身__STL_TEMPLATE_NULL struct hash<char> { size_t operator()(char __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<unsigned char> { size_t operator()(unsigned char __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<signed char> { size_t operator()(unsigned char __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<short> { size_t operator()(short __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<unsigned short> { size_t operator()(unsigned short __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<int> { size_t operator()(int __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<unsigned int> { size_t operator()(unsigned int __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<long> { size_t operator()(long __x) const { return __x; }};__STL_TEMPLATE_NULL struct hash<unsigned long> { size_t operator()(unsigned long __x) const { return __x; }};__STL_END_NAMESPACE#endif /* __SGI_STL_HASH_FUN_H */// Local Variables:// mode:C++// End:
0 0
- STL源码剖析 [容器](十九)[stl_hash_fun.h]
- STL源码剖析——stl_hash_fun.h学习
- STL源码剖析 [容器](一)[stl_vector.h]
- STL源码剖析 [容器](三)[stl_list.h]
- STL源码剖析 [容器](四)[stl_pair.h]
- STL源码剖析 [容器](五)[stl_deque.h]
- STL源码剖析 [容器](五)[stl_stack.h]
- STL源码剖析 [容器](六)[stl_queue.h]
- STL源码剖析 [容器](七)[stl_heap.h]
- STL源码剖析 [容器](九)[stl_slist.h ]
- STL源码剖析 [容器](十三)[stl_tree.h]
- STL源码剖析 [容器](十四)[stl_set.h]
- STL源码剖析 [容器](十五)[stl_multiset.h]
- STL源码剖析 [容器](十六)[stl_map.h]
- STL源码剖析 [容器](十七)[stl_multimap.h]
- STL源码剖析 [容器](十八)[stl_hashtable.h]
- STL源码剖析 [容器](二十)[stl_hash_set.h]
- STL源码剖析 [容器](二十一)[stl_hash_map.h]
- 得墨忒耳定律
- 编程规范
- python error: [Errno 10054]
- HDOJ 1171 Big Event in HDU(多重背包转化01背包 or 母函数)
- StartedService与BoundService 以及IntentService的简单使用
- STL源码剖析 [容器](十九)[stl_hash_fun.h]
- 航模小常识整理
- AbstractQueuedSynchronizer的实现分析(下)
- C# 去除HTML标签
- Android四大主件之广播BroadcastProvider
- 字符串匹配的KMP算法
- iOS -- 断点续传之 NSURLSession
- 关于iOS App 国际化和本地化 的一些总结:国际化 vs 本地化(Internationalization vs Localization)
- Eclipse中Build Path的使用介绍---学习笔记