更多内容推荐微信公众号,欢迎关注:

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算法的执行速度比较的更多相关文章

  1. HashMap中的hash算法总结

    前言 算法一直是我的弱项,然而面试中基本是必考的项目,刚好上次看到一个HashMap的面试题,今天也来学习下 HashMap中的hash算法是如何实现的. 数学知识回顾 << : 左移运算 ...

  2. 【Java深入研究】11、深入研究hashmap中的hash算法

    一.简介 大家都知道,HashMap中定位到桶的位置 是根据Key的hash值与数组的长度取模来计算的. JDK8中的hash 算法: static final int hash(Object key ...

  3. PHP中各种Hash算法性能比较

    国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...

  4. 图像相似度中的Hash算法

           度量两张图片的相似度有许多算法,本文讲介绍工程领域中最常用的图片相似度算法之一--Hash算法.Hash算法准确的说有三种,分别为平均哈希算法(aHash).感知哈希算法你(pHash) ...

  5. HashMap中的hash算法中的几个疑问

    HashMap中哈希算法的关键代码 //重新计算哈希值 static final int hash(Object key) { int h; return (key == null) ? 0 : (h ...

  6. [区块链] 密码学中Hash算法(基础)

    在介绍Hash算法之前,先给大家来个数据结构中对hash表(散列表)的简单解释,然后我再逐步深入,讲解一下hash算法. 一.Hash原理——基础篇 1.1 概念 哈希表就是一种以 键-值(key-i ...

  7. 用最简单的方式在C#中使用多线程加速耗时的图像处理算法的执行(多核机器)。

    图像处理中,有很多算法由于其内在的复杂性是天然的耗时大户,加之图像本身蕴涵的数据量比一般的对象就大,因此,针对这类算法,执行速度的提在很大程度上依赖于硬件的性能,现在流行的CPU都是至少2核的,稍微好 ...

  8. 字符串经典的hash算法

    1 概述 链表查找的时间效率为O(N),二分法为log2N,B+ Tree为log2N,但Hash链表查找的时间效率为O(1). 设计高效算法往往需要使用Hash链表,常数级的查找速度是任何别的算法无 ...

  9. hash算法和常见的hash函数 [转]

       Hash,就是把任意长度的输入,通过散列算法,变换成固定长度的输出,该输出就是散列值. 这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能 会散列成相同的输出,而不 ...

随机推荐

  1. 删除log日志中包含某个字符的行

    sed -i '/{Str}/d' abc.txt 假如你的log日志中某行有sleep字符,直接输入命令: sed -i '/sleep/d' log.log 如果删除的是一个变量的值,假如是var ...

  2. java中的==操作符和equals函数

    基本规则 “==”操作符的使用需要分成两种情况 判值类型相等 这一点很好理解,两个值类型代表的数值相等,则“==”表达式返回true “==”可以用与不同值类型的比较,语言会自动进行类型转换 判引用类 ...

  3. matlab dist函数

    dist——欧式距离加权函数(Euclidean distance weight function) 语法: Z = dist(W,P)    df = dist('deriv')    D = di ...

  4. Digits of Factorial LightOJ - 1045(数学题?)

    原文地址: https://blog.csdn.net/fenghoumilin/article/details/52293910 题意:求 n 的阶乘在 base 进制下的位数,这里有一个简单的方法 ...

  5. BZOJ 2527 Meteors | 整体二分

    BZOJ 2527 Meteors 题意 一个圆环上有m个位置,编号为1~m,分别属于n个国家. 有k个时刻,每个时刻都会给圆环上的一个区间中每个位置的值加上一个数. 每个国家有一个目标,问对于每个国 ...

  6. 【转】__ATTRIBUTE__ 你知多少

    __ATTRIBUTE__ 你知多少? GNU C 的一大特色就是__attribute__ 机制.__attribute__ 可以设置函数属性(Function Attribute ).变量属性(V ...

  7. BZOJ2525 [Poi2011]Dynamite 【二分 + 贪心】

    题目链接 BZOJ2525 题解 就是要求所有有炸弹的点到点燃点距离最大值最小 显然二分答案距离\(D\) 然后按深度排序,贪心点燃当前没覆盖的深度最深的点往上第\(D\)层的点 每覆盖一个点要标记其 ...

  8. 【THUSC2017】巧克力

    题目描述 ​“人生就像一盒巧克力,你永远不知道吃到的下一块是什么味道.” ​ 明明收到了一大块巧克力,里面有若干小块,排成n行m列.每一小块都有自己特别的图案ci,j,它们有的是海星,有的是贝壳,有的 ...

  9. 关于ASP.NET MVC的Html.BeginForm()方法

    http://zhidao.baidu.com/link?url=9j53URZJv2B9W-TPtQAaKCRbqIcYy2r3WNO0NDzciTON0EYj5Hhd3rl3UlIllK1CqOC ...

  10. C/C++ 多继承{虚基类,虚继承,构造顺序,析构顺序}

    C/C++:一个基类继承和多个基类继承的区别 1.对多个基类继承会出现类之间嵌套时出现的同名问题,如果同名变量或者函数出现不在同一层次,则底层派生隐藏外层比如继承基类的同名变量和函数,不会出现二义性, ...