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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
<?php
//ini_set('memory_limit' ,'128M');
$ary = get_loaded_extensions();
for($i=0; $i<pow(2, 9); $i++){
$ary = array_merge($ary, range(0, 1024));
$ary[] = md5("$i");
}
echo "count:".count($ary)."\n";
function getSize($ary)
{
if (ini_get('mbstring.func_overload') & 2 && function_exists('mb_strlen')) {
$size = mb_strlen($ary, 'ASCII');
} else {
$size = strlen($ary);
}
return $size;
}
echo "----\n";
echo "PHP\n";
$a = microtime(true);
$packed = serialize($ary);
$b = microtime(true);
echo ($refpck=($b-$a)) . " sec, " . ($refsize=getSize($packed)) . " bytes\n";
$a = microtime(true);
$pack = unserialize($packed);
$b = microtime(true);
echo ($refunp=($b-$a)) . " sec\n";
echo "----\n";
echo "IgBinary\n";
$a = microtime(true);
$packed = igbinary_serialize($ary);
$b = microtime(true);
echo ($t=($b-$a)) . " sec, " . round($t*100/$refpck) . "%, ". ($x=getSize($packed)) . " bytes, ".round($x*100/$refsize)."%\n";
$a = microtime(true);
$pack = igbinary_unserialize($packed);
$b = microtime(true);
echo ($t=($b-$a)) . " sec, " . round($t*100/$refunp) . "%\n";
echo "----\n";
echo "MessagePack\n";
$a = microtime(true);
$packed = msgpack_pack($ary);
$b = microtime(true);
echo ($t=($b-$a)) . " sec, " . round($t*100/$refpck) . "%, ". ($x=getSize($packed)) . " bytes, ".round($x*100/$refsize)."%\n";
$a = microtime(true);
$pack = msgpack_unpack($packed);
$b = microtime(true);
echo ($t=($b-$a)) . " sec, " . round($t*100/$refunp) . "%\n";
echo "----\n";
echo "JSON\n";
$a = microtime(true);
$jsoned = json_encode($ary);
$b = microtime(true);
echo ($t=($b-$a)) . " sec, " . round($t*100/$refpck) . "%, ". ($x=getSize($jsoned)) . " bytes, ".round($x*100/$refsize)."%\n";
$a = microtime(true);
$json = json_decode($jsoned);
$b = microtime(true);
echo ($t=($b-$a)) . " sec, " . round($t*100/$refunp) . "%\n";
?>
|