summaryrefslogtreecommitdiffstats
path: root/bench.php
blob: 130761b7210c7f7acd7f9fc642cea0325556cc43 (plain)
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";


?>