0

0

php字符串哈希函数算法实现代码

php中文网

php中文网

发布时间:2016-07-25 08:54:30

|

1598人浏览过

|

来源于php中文网

原创

  1. function DJBHash($str) // 0.22
  2. {
  3. $hash = 0;
  4. $n = strlen($str);
  5. for ($i = 0; $i
  6. {
  7. $hash += ($hash
  8. }
  9. return $hash % 701819;
  10. }
  11. function ELFHash($str) // 0.35
  12. {
  13. $hash = $x = 0;
  14. $n = strlen($str);
  15. for ($i = 0; $i
  16. {
  17. $hash = ($hash
  18. if(($x = $hash & 0xf0000000) != 0)
  19. {
  20. $hash ^= ($x>> 24);
  21. $hash &= ~$x;
  22. }
  23. }
  24. return $hash % 701819;
  25. }
  26. function JSHash($str) // 0.23
  27. {
  28. $hash = 0;
  29. $n = strlen($str);
  30. for ($i = 0; $i
  31. {
  32. $hash ^= (($hash > 2));
  33. }
  34. return $hash % 701819;
  35. }
  36. function SDBMHash($str) // 0.23
  37. {
  38. $hash = 0 ;
  39. $n = strlen($str);
  40. for ($i = 0; $i
  41. {
  42. $hash = ord($str[$i]) + ($hash
  43. }
  44. return $hash % 701819;
  45. }
  46. function APHash($str) // 0.30
  47. {
  48. $hash = 0 ;
  49. $n = strlen($str);
  50. for ($i = 0; $i
  51. {
  52. if (($i & 1 ) == 0 )
  53. {
  54. $hash ^= (($hash > 3 ));
  55. }
  56. else
  57. {
  58. $hash ^= ( ~ (($hash > 5)));
  59. }
  60. }
  61. return $hash % 701819;
  62. }
  63. function DEKHash($str) // 0.23
  64. {
  65. $n = strlen($str);
  66. $hash = $n;
  67. for ($i = 0; $i
  68. {
  69. $hash = (($hash > 27)) ^ ord($str[$i]);
  70. }
  71. return $hash % 701819;
  72. }
  73. function FNVHash($str) // 0.31
  74. {
  75. $hash = 0;
  76. $n = strlen($str);
  77. for ($i = 0; $i
  78. {
  79. $hash *= 0x811C9DC5;
  80. $hash ^= ord($str[$i]);
  81. }
  82. return $hash % 701819;
  83. }
  84. function PJWHash($str) // 0.33
  85. {
  86. $hash = $test = 0;
  87. $n = strlen($str);
  88. for ($i = 0; $i
  89. {
  90. $hash = ($hash
  91. if(($test = $hash & -268435456) != 0)
  92. {
  93. $hash = (( $hash ^ ($test>> 24)) & (~-268435456));
  94. }
  95. }
  96. return $hash % 701819;
  97. }
  98. function PHPHash($str) // 0.34
  99. {
  100. $hash = 0;
  101. $n = strlen($str);
  102. for ($i = 0; $i
  103. {
  104. $hash = ($hash
  105. if (($g = ($hash & 0xF0000000)))
  106. {
  107. $hash = $hash ^ ($g>> 24);
  108. $hash = $hash ^ $g;
  109. }
  110. }
  111. return $hash % 701819;
  112. }
  113. function OpenSSLHash($str) // 0.22
  114. {
  115. $hash = 0;
  116. $n = strlen($str);
  117. for ($i = 0; $i
  118. {
  119. $hash ^= (ord($str[$i])
  120. }
  121. return $hash % 701819;
  122. }
  123. function MD5Hash($str) // 0.050
  124. {
  125. $hash = md5($str);
  126. $hash = $hash[0] | ($hash[1]
  127. return $hash % 701819;
  128. }
复制代码

算法说明: 函数后面注释中是我本地测试的执行1000次的速度(单位:s),可以看出来MD5Hash是最快的,而且要比其他函数快很多很多...但是从这个函数的算法也可以看出来,它仅仅是依赖于md5后字符串的前7个字符,也就是说如果前7个字符相同的话那么获得的hash值是完全一样的,所以实际来说它的分布情况是不太令人信任的....如果按照32个字符来计算的话速度那就远远的慢于其他算法了...

除了MD5Hash,其他算法都会受到字符串长度的影响,越长越慢,我测试用的是10个字符的英文。 每个函数最后的 return $hash % 701819; 中 701819 表示是哈希的最大容积,也就是说这些哈希函数最后得到的数字范围是0~701819,这个数字是可以改的一般认为使用一个大的质数结果的分布会是比较均匀的,在 701819 附近的几个建议的值是:175447, 350899, 1403641, 2807303, 5614657。

这个到底可以用来做什么呢...

为什么要整理 and 测试这些哈希算法,我在写多用户 Blog,恩...之前的日志里面也有提过,多用户 Blog 一般都有一个功能,那就是使用一个英文和数字组合的用户名来作为 Blog 的地址(二级域名或者目录)。那么就有一个问题了,如何根据用户名来获取用户的 ID,多一次查询吗?有了哈希函数就不用了,使用哈希函数处理用户名,得到一个数字,再对数字做一定的处理(我是按照2位分割成层次的目录,目的是防止一个目录下有太多的文件而影响磁盘检索速度),然后就形成了一个路径,把对应的ID保存在这个路径下的文件内(我个人推荐用户名做文件名),这样就可以根据用户名来直接获得用户的ID,不需要查询,用户名做文件名,所以即使最后结果相同也是在不同的文件中,所以可以不用担心出现碰撞。

当然...如果你的系统完全是根据用户名来操作那当我前面这些都没说 = =b,悄悄的非议一句 SELECT 也是数字比字符串要快一些地。

我选择的是DJB算法,等以后上线后如果测试MD5分布还算可以接受的话再考虑换用。

MD5校验和计算小程序(C)
MD5校验和计算小程序(C)

C编写,实现字符串摘要、文件摘要两个功能。里面主要包含3个文件: Md5.cpp、Md5.h、Main.cpp。其中Md5.cpp是算法的代码,里的代码大多是从 rfc-1321 里copy过来的;Main.cpp是主程序。

下载

从这里也可以看出来其实哈希对于分布还是很有用地,呵呵,可以用来作缓存,静态或者其他需要分布存储的东西上面。

立即学习PHP免费学习笔记(深入)”;



相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

705

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

233

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

117

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

22

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

61

2026.02.13

c语言 数据类型
c语言 数据类型

本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

30

2026.02.12

雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

15

2026.02.12

豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

669

2026.02.12

PostgreSQL性能优化与索引调优实战
PostgreSQL性能优化与索引调优实战

本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

58

2026.02.12

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP基础入门课程
PHP基础入门课程

共33课时 | 2.2万人学习

Go语言教程-全程干货无废话
Go语言教程-全程干货无废话

共100课时 | 10.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号