PHP 递归效率分析
2015-01-24信息快讯网
PHP的递归效率一般认为是低效的。大概一年前,我写了一篇博文,对三种遍历树的方法进行了比较,发现递归算法的效率最低。
而且是差了3倍的效率。所以,PHP中的递归一定要小心的对待。最近写了一个快速排序的算法,发现PHP中的递归效率不能一刀切,在各种不同的服务器中,可能会表现不一样。
function qsort(&$arr) { _quick_sort($arr, 0, count($arr) - 1); } /** * 采用递归算法的快速排序。 * * @param array $arr 要排序的数组 * @param int $low 最低的排序子段 * @param int $high 最高的排序字段 */ function _quick_sort(&$arr, $low, $high) { $low_data = $arr[$low]; $prev_low = $low; $prev_high = $high; while ($low < $high) { while ($arr[$high] >= $low_data && $low < $high) { $high--; } if ($low < $high) { $arr[$low] = $arr[$high]; $low++; } while ($arr[$low] <= $low_data && $low < $high) { $low++; } if ($low < $high) { $arr[$high] = $arr[$low]; $high--; } } $arr[$low] = $low_data; if ($prev_low < $low) { _quick_sort($arr, $prev_low, $low); } if ($low + 1 < $prev_high) { _quick_sort($arr, $low + 1, $prev_high); } } function quick_sort(&$arr) { $stack = array(); array_push($stack, 0); array_push($stack, count($arr) -1); while (!empty($stack)) { $high = array_pop($stack); $low = array_pop($stack); $low_data = $arr[$low]; $prev_low = $low; $prev_high = $high; while ($low < $high) { while ($arr[$high] >= $low_data && $low < $high) { $high--; } if ($low < $high) { $arr[$low] = $arr[$high]; $low++; } while ($arr[$low] <= $low_data && $low < $high) { $low++; } if ($low < $high) { $arr[$high] = $arr[$low]; $high--; } } $arr[$low] = $low_data; if ($prev_low < $low) { array_push($stack, $prev_low); array_push($stack, $low); } if ($low + 1 < $prev_high) { array_push($stack, $low + 1); array_push($stack, $prev_high); } } }
下面是测试速度的代码:
function qsort_test1() { $arr = range(1, 1000); shuffle($arr); $arr2 = $arr; $t1 = microtime(true); quick_sort($arr2); $t2 = microtime(true) - $t1; echo "非递归调用的花费:" . $t2 . "\n"; $arr1 = $arr; $t1 = microtime(true); qsort($arr1); $t2 = microtime(true) - $t1; echo "递归调用的花费:" . $t2 . "\n"; }
在我的IIS 服务器上(CGI)模式,我的测试结果是:
非递归调用的花费:0.036401009559631
递归调用的花费:0.053439617156982
在我的Apache 服务器上,我的测试结果是:
非递归调用的花费:0.022789001464844
递归调用的花费:0.014809131622314
结果完全相反,而PHP的版本是一样的。
看来对递归的效率要具体问题具体分析了。
php自动获取字符串编码函数mb_detect_encoding
比较时间段一与时间段二是否有交集的php函数
实用PHP会员权限控制实现原理分析
允许phpmyadmin空密码登录的配置方法
php统计文件大小,以GB、MB、KB、B输出
rrmdir php中递归删除目录及目录下的文件
mysql_num_rows VS COUNT 效率问题分析
优化php效率,提高php性能的一些方法
php实现无限级分类实现代码(递归方法)
PHP 函数执行效率的小比较
PHP类中Static方法效率测试代码
提高PHP编程效率的53个要点(经验小结)
php递归实现无限分类生成下拉列表的函数
php自定义函数之递归删除文件及目录
用PHP实现递归循环每一个目录
PHP 进程锁定问题分析研究
PHP 单引号与双引号的区别
PHP小程序自动提交到自助友情连接
php 引用(&)详解
php+javascript的日历控件
php与XML、XSLT、Mysql的结合运用实现代码
PHP的单引号和双引号 字符串效率
php递归列出所有文件和目录的代码
效率较高的php下读取文本文件的代码 原创
php MySQL与分页效率
Http 1.1 Etag 与 Last-Modified提高php效率