没有合适的资源?快使用搜索试试~ 我知道了~
php的hash算法介绍
0 下载量 65 浏览量
2020-12-18
22:08:59
上传
评论
收藏 64KB PDF 举报
温馨提示
试读
2页
Hash Table是PHP的核心,这话一点都不过分。 PHP的数组,关联数组,对象属性,函数表,符号表,等等都是用HashTable来做为容器的。 PHP的HashTable采用的拉链法来解决冲突, 这个自不用多说, 我今天主要关注的就是PHP的Hash算法, 和这个算法本身透露出来的一些思想。 PHP的Hash采用的是目前最为普遍的DJBX33A (Daniel J. Bernstein, Times 33 with Addition), 这个算法被广泛运用与多个软件项目,Apache, Perl和Berkeley DB等. 对于字符串而言这是目前所知道的最好的哈希算法,原因在于该算法的速
资源详情
资源评论
资源推荐
php的的hash算法介绍算法介绍
Hash Table是PHP的核心,这话一点都不过分。
PHP的数组,关联数组,对象属性,函数表,符号表,等等都是用HashTable来做为容器的。
PHP的HashTable采用的拉链法来解决冲突, 这个自不用多说, 我今天主要关注的就是PHP的Hash算法, 和这个算法本身透露出
来的一些思想。
PHP的Hash采用的是目前最为普遍的DJBX33A (Daniel J. Bernstein, Times 33 with Addition), 这个算法被广泛运用与多个软
件项目,Apache, Perl和Berkeley DB等. 对于字符串而言这是目前所知道的最好的哈希算法,原因在于该算法的速度非常快,
而且分类非常好(冲突小,分布均匀).
算法的核心思想就是:
复制代码 代码如下:
hash(i) = hash(i-1) * 33 + str[i]
在zend_hash.h中,我们可以找到在PHP中的这个算法:
复制代码 代码如下:
static inline ulong zend_inline_hash_func(char *arKey, uint nKeyLength)
{
register ulong hash = 5381;
/* variant with the hash unrolled eight times */
for (; nKeyLength >= 8; nKeyLength -= {
hash = ((hash << 5) + hash) + *arKey++;
hash = ((hash << 5) + hash) + *arKey++;
hash = ((hash << 5) + hash) + *arKey++;
hash = ((hash << 5) + hash) + *arKey++;
hash = ((hash << 5) + hash) + *arKey++;
hash = ((hash << 5) + hash) + *arKey++;
hash = ((hash << 5) + hash) + *arKey++;
hash = ((hash << 5) + hash) + *arKey++;
}
switch (nKeyLength) {
case 7: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough… */
case 6: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough… */
case 5: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough… */
case 4: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough… */
case 3: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough… */
case 2: hash = ((hash << 5) + hash) + *arKey++; /* fallthrough… */
case 1: hash = ((hash << 5) + hash) + *arKey++; break;
case 0: break;
EMPTY_SWITCH_DEFAULT_CASE()
}
return hash;
}
相比在Apache和Perl中直接采用的经典Times 33算法:
复制代码 代码如下:
hashing function used in Perl 5.005:
# Return the hashed value of a string: $hash = perlhash(“key”)
# (Defined by the PERL_HASH macro in hv.h)
weixin_38695293
- 粉丝: 6
- 资源: 956
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- apk.tw_LineLite_v8a_v.2.17.1_sign.apk
- Elasticsearch实战:构建高效搜索系统的秘诀.zip
- HTML+CSS+JS网页设计:从入门到精通.zip
- 数据库课程设计:从理论到实践的全面指南.zip
- Python闭包:深入理解与应用场景解析.zip
- Win64OpenSSL-3-3-0.exe
- 课高分程设计-基于C++实现的民航飞行与地图简易管理系统-南京航空航天大学
- 航天器遥测数据故障检测系统python源码+文档说明+数据库(课程设计)
- 北京航空航天大学操作系统课设+ppt+实验报告
- 基于Vue+Echarts实现风力发电机中传感器的数据展示监控可视化系统+源代码+文档说明(高分课程设计)
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0