- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章PHP实现的各类hash算法长度及性能测试实例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文实例讲述了PHP实现的各类hash算法长度及性能测试。分享给大家供大家参考,具体如下:
Hash结果如下 。
1
2
3
4
5
6
7
|
<?php
$data
=
"hello world"
;
foreach
(hash_algos()
as
$v
) {
$r
= hash(
$v
,
$data
, false);
printf(
"%-12s %3d %s\n"
,
$v
,
strlen
(
$r
),
$r
);
}
?>
|
运行结果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
md2 32 d9cce882ee690a5c1ce70beff3a78c77
md4 32 aa010fbc1d14c795d86ef98c95479d17
md5 32 5eb63bbbe01eeed093cb22bb8f5acdc3
sha1 40 2aae6c35c94fcfb415dbe95f408b9ce91ee846ed
sha224 56 2f05477fc24bb4faefd86517156dafdecec45b8ad3cf2522a563582b
sha256 64 b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9
sha384 96 fdbd8e75a67f29f701a4e040385e2e23986303ea10239211af907fcbb83578b3e417cb71ce646efd0819dd8c088de1bd
sha512 128 309ecc489c12d6eb4cc40f50c902f2b4d0ed77ee511a7c7a9bcd3ca86d4cd86f989dd35bc5ff499670da34255b45b0cfd830e81f605dcf7dc5542e93ae9cd76f
ripemd128 32 c52ac4d06245286b33953957be6c6f81
ripemd160 40 98c615784ccb5fe5936fbc0cbe9dfdb408d92f0f
ripemd256 64 0d375cf9d9ee95a3bb15f757c81e93bb0ad963edf69dc4d12264031814608e37
ripemd320 80 0e12fe7d075f8e319e07c106917eddb0135e9a10aefb50a8a07ccb0582ff1fa27b95ed5af57fd5c6
whirlpool 128 8d8309ca6af848095bcabaf9a53b1b6ce7f594c1434fd6e5177e7e5c20e76cd30936d8606e7f36acbef8978fea008e6400a975d51abe6ba4923178c7cf90c802
tiger128,3 32 4c8fbddae0b6f25832af45e7c62811bb
tiger160,3 40 4c8fbddae0b6f25832af45e7c62811bb64ec3e43
tiger192,3 48 4c8fbddae0b6f25832af45e7c62811bb64ec3e43691e9cc3
tiger128,4 32 24465a3f6e4aa92d903ee535476591e9
tiger160,4 40 24465a3f6e4aa92d903ee535476591e937f3a14d
tiger192,4 48 24465a3f6e4aa92d903ee535476591e937f3a14d81c4c7b6
snefru 64 902b49fa8b0828b44d8ac069111899bbfaf51d334485e4b28e90c93f63bb86dd
snefru256 64 902b49fa8b0828b44d8ac069111899bbfaf51d334485e4b28e90c93f63bb86dd
gost 64 1bb6ce69d2e895a78489c87a0712a2f40258d1fae3a4666c23f8f487bef0e22a
gost-crypto 64 c5aa1455afe9f0c440eec3c96ccccb5c8495097572cc0f625278bd0da5ea5e07
adler32 8 1a0b045d
crc32 8 7813f744
crc32b 8 0d4a1185
fnv132 8 548da96f
fnv1a32 8 d58b3fa7
fnv164 16 7dcf62cdb1910e6f
fnv1a64 16 779a65e7023cd2e7
joaat 8 3e4a5a57
haval128,3 32 906c1df7cbe6d318f36ab172f95e89c0
haval160,3 40 6e733b21876e47c2168a122e23d86bdd69e50f95
haval192,3 48 ec67a6a417953fdbf3496502004b6c21b270d5890dedd931
haval224,3 56 766879d9ba1dc9e24a6040908a7ae813a47b08af5c5f3beebcacda48
haval256,3 64 45492c6c8adab277759f4381420799431a037daf6d829b8b5c21104c10f61a92
haval128,4 32 c97d46956b8e3e60acd2bb090c482c5e
haval160,4 40 2cb8b12eb5a2561022010c2a2af8795e602fdef2
haval192,4 48 39a281e4e492533b6dfea0af294149ccac771ab87204c9ec
haval224,4 56 3d64d34aea48f5e649ed6147da5d29d31c762a937e9e21f4da1f3106
haval256,4 64 0359a526d77e271707c44d9b270e68a394f8486a459f0137ad5e1d02e44c5889
haval128,5 32 8332ad9f32e385d9acd421b63ee04cfc
haval160,5 40 d33cf9052d55da9b0f506cb8849097939363e361
haval192,5 48 67c3492878c8fc4819c8589231fcfe69b15b015c1ca48ac5
haval224,5 56 6bedeb6a8676e46413c020c8813c022486ca93353b8a0673fb577ba1
haval256,5 64 f5f6ffcfe39a65ac2c3989430340420341762a6624ebd69b9d08ec1dc4b9f167
|
性能测试如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
<?php
define(
'testtime'
, 1000000);
$algos
= hash_algos();
foreach
(
$algos
as
$algo
) {
$st
= microtime();
for
(
$i
= 0;
$i
< testtime;
$i
++) {
hash(
$algo
, microtime().
$i
);
}
$et
= microtime();
list(
$ss
,
$si
) =
explode
(
' '
,
$st
);
list(
$es
,
$ei
) =
explode
(
' '
,
$et
);
$time
[
$algo
] =
$ei
+
$es
-
$si
-
$ss
;
}
asort(
$time
, SORT_NUMERIC);
print_r(
$time
);
?>
|
运行结果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
Array
(
[fnv1a32] => 1.4528379546356
[fnv164] => 1.4598390410767
[fnv1a64] => 1.4685498960724
[fnv132] => 1.4695508840027
[crc32b] => 1.480463955719
[adler32] => 1.481206043457
[joaat] => 1.4851269485474
[crc32] => 1.508364085907
[md4] => 1.6973789288788
[md5] => 1.7637529927979
[sha1] => 1.932477017334
[tiger128,3] => 1.9683119142761
[tiger160,3] => 1.9759550503387
[ripemd128] => 2.0003409449921
[tiger192,3] => 2.0107291056519
[tiger128,4] => 2.0609339611664
[tiger160,4] => 2.0614830404358
[ripemd256] => 2.1055679496613
[tiger192,4] => 2.1089930283813
[ripemd320] => 2.3564790057831
[ripemd160] => 2.3820580299072
[sha256] => 2.3944439311981
[sha224] => 2.4205659084473
[haval128,3] => 2.5319820201874
[haval224,3] => 2.5319839861755
[haval160,3] => 2.5347460784149
[haval192,3] => 2.5500600071869
[haval256,3] => 2.580485933548
[sha384] => 2.6736448852386
[sha512] => 2.721533025589
[haval224,4] => 2.9019400155029
[haval128,4] => 2.9155439011078
[haval256,4] => 2.9168769813385
[haval160,4] => 2.9341630749512
[haval192,4] => 2.9478991126251
[haval192,5] => 3.1933639251862
[haval256,5] => 3.1942859609985
[haval160,5] => 3.1946619862823
[whirlpool] => 3.1954451004639
[haval128,5] => 3.2122300287323
[haval224,5] => 3.295264964798
[gost] => 4.6756690344391
[gost-crypto] => 4.6819899302826
[snefru] => 6.5784390528107
[snefru256] => 6.6484970919647
[md2] => 11.291653894501
)
|
希望本文所述对大家PHP程序设计有所帮助.
原文链接:http://www.cnblogs.com/ciaos/p/4821319.html 。
最后此篇关于PHP实现的各类hash算法长度及性能测试实例的文章就讲到这里了,如果你想了解更多关于PHP实现的各类hash算法长度及性能测试实例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
滑动窗口限流 滑动窗口限流是一种常用的限流算法,通过维护一个固定大小的窗口,在单位时间内允许通过的请求次数不超过设定的阈值。具体来说,滑动窗口限流算法通常包括以下几个步骤: 初始化:设置窗口
表达式求值:一个只有+,-,*,/的表达式,没有括号 一种神奇的做法:使用数组存储数字和运算符,先把优先级别高的乘法和除法计算出来,再计算加法和减法 int GetVal(string s){
【算法】前缀和 题目 先来看一道题目:(前缀和模板题) 已知一个数组A[],现在想要求出其中一些数字的和。 输入格式: 先是整数N,M,表示一共有N个数字,有M组询问 接下来有N个数,表示A[1]..
1.前序遍历 根-左-右的顺序遍历,可以使用递归 void preOrder(Node *u){ if(u==NULL)return; printf("%d ",u->val);
先看题目 物品不能分隔,必须全部取走或者留下,因此称为01背包 (只有不取和取两种状态) 看第一个样例 我们需要把4个物品装入一个容量为10的背包 我们可以简化问题,从小到大入手分析 weightva
我最近在一次采访中遇到了这个问题: 给出以下矩阵: [[ R R R R R R], [ R B B B R R], [ B R R R B B], [ R B R R R R]] 找出是否有任
我正在尝试通过 C++ 算法从我的 outlook 帐户发送一封电子邮件,该帐户已经打开并记录,但真的不知道从哪里开始(对于 outlook-c++ 集成),谷歌也没有帮我这么多。任何提示将不胜感激。
我发现自己像这样编写了一个手工制作的 while 循环: std::list foo; // In my case, map, but list is simpler auto currentPoin
我有用于检测正方形的 opencv 代码。现在我想在检测正方形后,代码运行另一个命令。 代码如下: #include "cv.h" #include "cxcore.h" #include "high
我正在尝试模拟一个 matlab 函数“imfill”来填充二进制图像(1 和 0 的二维矩阵)。 我想在矩阵中指定一个起点,并像 imfill 的 4 连接版本那样进行洪水填充。 这是否已经存在于
我正在阅读 Robert Sedgewick 的《C++ 算法》。 Basic recurrences section it was mentioned as 这种循环出现在循环输入以消除一个项目的递
我正在思考如何在我的日历中生成代表任务的数据结构(仅供我个人使用)。我有来自 DBMS 的按日期排序的任务记录,如下所示: 买牛奶(18.1.2013) 任务日期 (2013-01-15) 任务标签(
输入一个未排序的整数数组A[1..n]只有 O(d) :(d int) 计算每个元素在单次迭代中出现在列表中的次数。 map 是balanced Binary Search Tree基于确保 O(nl
我遇到了一个问题,但我仍然不知道如何解决。我想出了如何用蛮力的方式来做到这一点,但是当有成千上万的元素时它就不起作用了。 Problem: Say you are given the followin
我有一个列表列表。 L1= [[...][...][.......].......]如果我在展平列表后获取所有元素并从中提取唯一值,那么我会得到一个列表 L2。我有另一个列表 L3,它是 L2 的某个
我们得到二维矩阵数组(假设长度为 i 和宽度为 j)和整数 k我们必须找到包含这个或更大总和的最小矩形的大小F.e k=7 4 1 1 1 1 1 4 4 Anwser是2,因为4+4=8 >= 7,
我实行 3 类倒制,每周换类。顺序为早类 (m)、晚类 (n) 和下午类 (a)。我固定的订单,即它永远不会改变,即使那个星期不工作也是如此。 我创建了一个函数来获取 ISO 周数。当我给它一个日期时
假设我们有一个输入,它是一个元素列表: {a, b, c, d, e, f} 还有不同的集合,可能包含这些元素的任意组合,也可能包含不在输入列表中的其他元素: A:{e,f} B:{d,f,a} C:
我有一个子集算法,可以找到给定集合的所有子集。原始集合的问题在于它是一个不断增长的集合,如果向其中添加元素,我需要再次重新计算它的子集。 有没有一种方法可以优化子集算法,该算法可以从最后一个计算点重新
我有一个包含 100 万个符号及其预期频率的表格。 我想通过为每个符号分配一个唯一(且前缀唯一)的可变长度位串来压缩这些符号的序列,然后将它们连接在一起以表示序列。 我想分配这些位串,以使编码序列的预
我是一名优秀的程序员,十分优秀!