php中各种hash算法的执行速度比较
更多内容推荐微信公众号,欢迎关注:
PHP中的Hash函数很多,像MD4、MD5、SHA-1、SHA-256、SHA-384、SHA-512等我们比较常见,那么各个哈希的执行速度呢?
$algos = hash_algos(); foreach ($algos as $algo){ $start = microtime(true); for($i=0; $i<50000; $i++){ hash($algo, microtime().$i); } $end = microtime(true); $timeres[$algo] = $end-$start; } asort($timeres, SORT_NUMERIC); print_r($timeres);
对每个hash函数执行5000次,比较时间的长短。
运行结果如下:
[fnv1a32] => 0.31601810455322 [crc32] => 0.31901788711548 [joaat] => 0.31901788711548 [fnv132] => 0.32001781463623 [adler32] => 0.32201790809631 [fnv164] => 0.32901906967163 [fnv1a64] => 0.33101892471313 [crc32b] => 0.33302021026611 [md4] => 0.34102010726929 [sha256] => 0.37002110481262 [ripemd160] => 0.37002110481262 [haval160,3] => 0.37302088737488 [haval192,3] => 0.37402105331421 [haval128,3] => 0.37902212142944 [sha1] => 0.3800220489502 [tiger160,3] => 0.38202214241028 [md5] => 0.38302183151245 [haval224,3] => 0.38402199745178 [ripemd128] => 0.38702178001404 [sha224] => 0.38702201843262 [haval256,3] => 0.38802194595337 [haval192,4] => 0.39402318000793 [ripemd320] => 0.39602184295654 [tiger192,3] => 0.39702296257019 [haval256,4] => 0.39802312850952 [ripemd256] => 0.39902305603027 [haval160,4] => 0.40202283859253 [haval224,4] => 0.40202283859253 [haval192,5] => 0.41402387619019 [haval224,5] => 0.41502404212952 [tiger160,4] => 0.41502404212952 [haval160,5] => 0.41502404212952 [haval128,5] => 0.4170229434967 [tiger192,4] => 0.42202401161194 [tiger128,4] => 0.42502403259277 [haval256,5] => 0.44202518463135 [tiger128,3] => 0.44602489471436 [haval128,4] => 0.45202612876892 [sha512] => 0.45602607727051 [sha384] => 0.46702694892883 [whirlpool] => 0.51503014564514 [gost-crypto] => 0.51803016662598 [gost] => 0.52102994918823 [snefru256] => 0.60203409194946 [snefru] => 0.60903477668762 [md2] => 0.61003494262695
如上,CRC是冗余验证算法,不适合用来做唯一标识符Hash计算
执行速度上,md4 > sha256 > sha1 > md5
将标识转化为长字符串可以用md4()
密码上来说,sha256比sha1快速好用且安全
php中各种hash算法的执行速度比较的更多相关文章
- HashMap中的hash算法总结
前言 算法一直是我的弱项,然而面试中基本是必考的项目,刚好上次看到一个HashMap的面试题,今天也来学习下 HashMap中的hash算法是如何实现的. 数学知识回顾 << : 左移运算 ...
- 【Java深入研究】11、深入研究hashmap中的hash算法
一.简介 大家都知道,HashMap中定位到桶的位置 是根据Key的hash值与数组的长度取模来计算的. JDK8中的hash 算法: static final int hash(Object key ...
- PHP中各种Hash算法性能比较
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- 图像相似度中的Hash算法
度量两张图片的相似度有许多算法,本文讲介绍工程领域中最常用的图片相似度算法之一--Hash算法.Hash算法准确的说有三种,分别为平均哈希算法(aHash).感知哈希算法你(pHash) ...
- HashMap中的hash算法中的几个疑问
HashMap中哈希算法的关键代码 //重新计算哈希值 static final int hash(Object key) { int h; return (key == null) ? 0 : (h ...
- [区块链] 密码学中Hash算法(基础)
在介绍Hash算法之前,先给大家来个数据结构中对hash表(散列表)的简单解释,然后我再逐步深入,讲解一下hash算法. 一.Hash原理——基础篇 1.1 概念 哈希表就是一种以 键-值(key-i ...
- 用最简单的方式在C#中使用多线程加速耗时的图像处理算法的执行(多核机器)。
图像处理中,有很多算法由于其内在的复杂性是天然的耗时大户,加之图像本身蕴涵的数据量比一般的对象就大,因此,针对这类算法,执行速度的提在很大程度上依赖于硬件的性能,现在流行的CPU都是至少2核的,稍微好 ...
- 字符串经典的hash算法
1 概述 链表查找的时间效率为O(N),二分法为log2N,B+ Tree为log2N,但Hash链表查找的时间效率为O(1). 设计高效算法往往需要使用Hash链表,常数级的查找速度是任何别的算法无 ...
- hash算法和常见的hash函数 [转]
Hash,就是把任意长度的输入,通过散列算法,变换成固定长度的输出,该输出就是散列值. 这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能 会散列成相同的输出,而不 ...
随机推荐
- ACM数论之旅1---素数(万事开头难(>_<))
前言:好多学ACM的人都在问我数论的知识(其实我本人分不清数学和数论有什么区别,反正以后有关数学的知识我都扔进数论分类里面好了) 于是我就准备写一个长篇集,把我知道的数论知识和ACM模板都发上来(而且 ...
- ACdream原创群赛__15
这场感觉题目确实还算可以,不过,说好的每题10s效果上却不理想.这个时限还算比较紧.因为时间不是按绝对的多出几秒来计算,而是几倍来计算的. 比赛做的不好,后面又去做了一下. A:典型的数位DP,一直坑 ...
- 你好,OI
高二了才开通真正意义上的博客...以前一直比较懒没写过什么,现在为了给自己留下一点回忆还是过来了. 上半年的那次失败还是历历在目啊...几个月来一直在我心中挥之不去.虽说也是自己的能力不足造成的,但是 ...
- Python语言算法的时间复杂度和空间复杂度
算法复杂度分为时间复杂度和空间复杂度. 其作用: 时间复杂度是指执行算法所需要的计算工作量: 而空间复杂度是指执行这个算法所需要的内存空间. (算法的复杂性体现在运行该算法时的计算机所需资源的多少上, ...
- BZOJ1064 NOI2008假面舞会(dfs树)
将图中的环的长度定义为正向边数量-反向边数量,那么答案一定是所有环的环长的共同因子.dfs一下就能找到图中的一些环,并且图中的所有环的环长都可以由这些环长加加减减得到(好像不太会证).如果有环长为1或 ...
- 何登成大神对Innodb加锁的分析
背景 MySQL/InnoDB的加锁分析,一直是一个比较困难的话题.我在工作过程中,经常会有同事咨询这方面的问题.同时,微博上也经常会收到MySQL锁相关的私信,让我帮助解决一些死锁的问题.本文,准备 ...
- 【刷题】LOJ 6000 「网络流 24 题」搭配飞行员
题目描述 飞行大队有若干个来自各地的驾驶员,专门驾驶一种型号的飞机,这种飞机每架有两个驾驶员,需一个正驾驶员和一个副驾驶员.由于种种原因,例如相互配合的问题,有些驾驶员不能在同一架飞机上飞行,问如何搭 ...
- 记一个鼠标略过时候的css动画
.circle{ width: 15px; height: 15px; background: rgba(0,0,0,0.7); border-radius: 50%; display: table- ...
- 【算法】Tarjan大锦集
Task1 Description 一位冷血的杀手潜入 Na-wiat,并假装成平民.警察希望能在 N 个人里面,查出谁是杀手. 警察能够对每一个人进行查证,假如查证的对象是平民,他会告诉警察,他认识 ...
- 【BZOJ3884】上帝与集合的正确用法
Description 一句话题意,给定\(p\)作为模数: \(p\le 10^7\),数据组数\(T\le1000\). Solution 看到就弃疗了,再见...... 将模数\(p\)拆分成\ ...