函数执行效率的小比较----PHP 函数学习
如题:要求写一个自定义函数,使 $data = array(12, 43, 87, 45) => $data = array(1, 2, 4, 3, 8, 7, 4, 5);
就是把原来的数组中的数都“拆”成“单”位的。
下面是自己写的一个函数:
function splitStrToArray_mine($array) { $new_array = array(); foreach($array as $value) { $value = (string)$value; $len = strlen($value); for($i = 0; $i < $len; $i ++){ array_push($new_array, $value{$i}); } } return $new_array; }
测试了一下,还是可以执行的,如下调用:
//测试数组 $data = array(12, 43, 87, 45, 98, 74, 83, 67, 12); var_dump(splitStrToArray_mine($data));
输出结果为:
array(18) { [0]=> string(1) "1" [1]=> string(1) "2" [2]=> string(1) "4" [3]=> string(1) "3" [4]=> string(1) "8" [5]=> string(1) "7" [6]=> string(1) "4" [7]=> string(1) "5" [8]=> string(1) "9" [9]=> string(1) "8" [10]=> string(1) "7" [11]=> string(1) "4" [12]=> string(1) "8" [13]=> string(1) "3" [14]=> string(1) "6" [15]=> string(1) "7" [16]=> string(1) "1" [17]=> string(1) "2" }
虽然执行的不错,但是看看标准答案就会让你大吃一惊的,函数中就一句话,如下:
//标准函数 function splitStrToArray($array) { return str_split(implode("", $array)); }
于是写了脚本来测试自己的和标准的函数的运行效率差距,里面有一个 microtime_float() 函数用来提供精确时间的支持:
//测量时间的函数 function microtime_float() { list($usec, $sec) = explode(" ", microtime()); return ((float)$usec + (float)$sec); } //自定义函数 function splitStrToArray_mine($array) { $new_array = array(); foreach($array as $value) { $value = (string)$value; $len = strlen($value); for($i = 0; $i < $len; $i ++){ array_push($new_array, $value{$i}); } } return $new_array; } //标准函数 function splitStrToArray($array) { return str_split(implode("", $array)); } //测试数组 $data = array(12, 43, 87, 45, 98, 74, 83, 67, 12); //开始测试 $mine_start = microtime_float(); splitStrToArray_mine($data); $mine_end = microtime_float(); //标准函数调用 $sta_start = microtime_float(); splitStrToArray($data); $sta_end = microtime_float(); echo "自己的函数调用运行时间为:" . (float)($mine_end - $mine_start) . " S <br />"; echo "标准的函数调用运行时间为:" . (float)($sta_end - $sta_start) . " S <br />"; $multiple = (int)((float)($mine_end - $mine_start) / (float)($sta_end - $sta_start)); echo "前者是后者的:" . $multiple . " 倍!";
来看看输出结果:
自己的函数调用运行时间为:9.3936920166E-005 S 标准的函数调用运行时间为:2.69412994385E-005 S 前者是后者的:3 倍!
多次刷新页面的话,可以发现标准函数的执行效率基本上是自己的函数的 3 倍!当然,标准的函数中使用了 PHP 的内置函数: str_split(),implode(),所以要比自己写函数快得多,对 str_split() 函数没有印象?来看看手册解释:
str_split -- Convert a string to an array(将一个字符串转换成数组)
函数描述:
array str_split ( string string [, int split_length] )
Converts a string to an array. If the optional split_length parameter is specified, the returned array will be broken down into chunks with each being split_length in length, otherwise each chunk will be one character in length. FALSE is returned if split_length is less than 1. If the split_length length exceeds the length of string, the entire string is returned as the first (and only) array element.
例 1. Example uses of str_split()
<?php $str = "Hello Friend"; $arr1 = str_split($str); $arr2 = str_split($str, 3); print_r($arr1); print_r($arr2); ?>
Output may look like:
Array ( [0] => H [1] => e [2] => l [3] => l [4] => o [5] => [6] => F [7] => r [8] => i [9] => e [10] => n [11] => d ) Array ( [0] => Hel [1] => lo [2] => Fri [3] => end )