PHPWind与Discuz截取字符函数substrs与cutstr性能比较
2015-01-24信息快讯网
PHP性能优化系列第四期实战篇,如何使用PEAR Benchmark类工具获取函数执行性能,这里以PHPWind与Discuz!两个社区论坛的截取字符函数substrs与cutstr为例,分析两个函数的执行性能情况
以掌握使用Benchmark_Iterate类工具的方法。目录
一,什么是PEAR与Benchmark
二,性能比较代码准备与调试
三,性能比较测试结果
四,性能比较测试总结
五,附性能比较源代码下载
一,什么是PEAR与Benchmark
请参考PHP性能优化系列
第二期 PHP性能优化工具篇Benchmark类调试执行时间
第一期 PHP性能优化准备篇图解PEAR安装
二,性能比较代码准备与调试
测试环境说明
操作系统:Windows xp Service Pack 3
PHP版本:PHP Version 5.2.11
Apache版本:Apache 2.0 Handler
第一步,下载phpwind与discuz!程序源代码
1,下载 phpwind v7.5sp3 论坛版 安装包:简体 GBK
2,下载 Discuz! 7.2_FULL(含UCenter) 简体GBK
第二步,分别获取两个程序的截取字符函数substrs()和cutstr(),其中PHPWind截取字符函数substrs()由两个函数组成,分别是substrs与utf8_trim函数。
function substrs($content,$length,$add='Y'){ if (strlen($content)>$length) { if ($GLOBALS['db_charset']!='utf-8') { $retstr = ''; for ($i=0;$i<$length-2;$i++) { $retstr .= ord($content[$i]) > 127 ? $content[$i].$content[++$i] : $content[$i]; } return $retstr.($add=='Y' ? ' ..' : ''); } return utf8_trim(substr($content,0,$length)).($add=='Y' ? ' ..' : ''); } return $content; } function utf8_trim($str) { $hex = ''; $len = strlen($str)-1; for ($i=$len;$i>=0;$i-=1) { $ch = ord($str[$i]); $hex .= " $ch"; if (($ch & 128)==0 || ($ch & 192)==192) { return substr($str,0,$i); } } return $str.$hex; } function cutstr($string, $length, $dot = ' ...') { global $charset; if(strlen($string) <= $length) { return $string; } $string = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $string); $strcut = ''; if(strtolower($charset) == 'utf-8') { $n = $tn = $noc = 0; while($n < strlen($string)) { $t = ord($string[$n]); if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) { $tn = 1; $n++; $noc++; } elseif(194 <= $t && $t <= 223) { $tn = 2; $n += 2; $noc += 2; } elseif(224 <= $t && $t <= 239) { $tn = 3; $n += 3; $noc += 2; } elseif(240 <= $t && $t <= 247) { $tn = 4; $n += 4; $noc += 2; } elseif(248 <= $t && $t <= 251) { $tn = 5; $n += 5; $noc += 2; } elseif($t == 252 || $t == 253) { $tn = 6; $n += 6; $noc += 2; } else { $n++; } if($noc >= $length) { break; } } if($noc > $length) { $n -= $tn; } $strcut = substr($string, 0, $n); } else { for($i = 0; $i < $length; $i++) { $strcut .= ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i]; } } $strcut = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $strcut); return $strcut.$dot; }
第三步,编写使用PEAR Benchmark_Iterate类调试的代码
<?php require_once "Benchmark/Iterate.php"; $bench = new Benchmark_Iterate; $charset = $GLOBALS['db_charset'] = 'gbk';//utf-8 $content = "今年春晚,我特地关注了赵本山的新小品《捐助》,这篇小品对弱势群体的不尊重并无改变,小品讲的是赵本山与其弟子扮演两个捐助者..."; /*phpwind*/ $bench->run(50,"substrs",$content,30); /*discuz*/ //$bench->run(50,"cutstr",$content,30); $result = $bench->get(); ?>
分别切换substrs和cutstr两个函数并且调用50次获取两个函数执行的平均时间。
三,性能比较测试结果
1,PHPWind程序substrs函数当截取字符编码为GBK的情况
图解:PHPWind程序substrs函数截取GBK编码的字符平均时间在0.0014s-0.0015s之间,纵坐标表示执行的时间,横坐标表示执行的次数,图表中mean表示平均执行时间,注s表示秒
2,Discuz!程序cutstr函数当截取字符编码为GBK的情况
图解:Discuz!程序cutstr函数截取GBK编码的字符平均时间在0.0016s-0.0018s之间
3,PHPWind程序substrs函数当截取字符编码为UTF-8的情况
图解:PHPWind程序substrs函数截取UTF-8编码的字符平均时间在0.001s-0.0012s之间
4,Discuz!程序cutstr函数当截取字符编码为UTF-8的情况
图解:Discuz!程序cutstr函数截取UTF-8编码的字符平均时间在0.0044s-0.0052s之间
四,性能比较测试总结
如上使用PEAR的Benchmark_Iterate类比较了两个截取字符函数的执行性能,在实际的代码开发过程中,为了保证代码的效率与性能,我们可以采取同样的方法来分析函数的执行性能或问题,这个非常有用!
本文通过比较PHPWind与Discuz两个社区论坛产品的截取字符函数substrs与cutstr的执行性能情况为例,谈谈PEAR Benchmark_Iterate类在实际开发中的应用,请继续关注下期的PHP性能优化系列。
CURL的学习和应用(附多线程实现)
PHP register_shutdown_function函数的深入解析
基于session_unset与session_destroy的区别详解
基于PHP CURL获取邮箱地址的详解
详解PHP内置访问资源的超时时间 time_out file_get_contents read_file
基于Discuz security.inc.php代码的深入分析
spl_autoload_register与autoload的区别详解
基于Linux调试工具strace与gdb的常用命令总结
linux命令之调试工具strace的深入分析
如何使用Strace调试工具
php curl的深入解析
php 深入理解strtotime函数的使用详解
LotusPhp笔记之:基于ObjectUtil组件的使用分析
基于curl数据采集之正则处理函数get_matches的使用
input file获得文件根目录简单实现
PHP性能优化准备篇图解PEAR安装
php的chr和ord函数实现字符加减乘除运算实现代码
PHP中strtotime函数使用方法详解
DISCUZ在win2003环境下 Unable to access ./include/common.inc.php in... 的问题终极解决方案
PHP中文处理 中文字符串截取(mb_substr)和获取中文字符串字数
php空间不支持socket但支持curl时recaptcha的用法
php获取远程图片的两种 CURL方式和sockets方式获取远程图片
php smarty截取中文字符乱码问题?gb2312/utf-8
提示Trying to clone an uncloneable object of class Imagic的解决
PHP中的strtr函数使用介绍(str_replace)
Array of country list in PHP with Zend Framework
php下利用curl判断远程文件是否存在的实现代码
php中使用Curl、socket、file_get_contents三种方法POST提交数据
QQ登录 PHP OAuth示例代码
PHP通过iconv将字符串从GBK转换为UTF8字符集
php max_execution_time执行时间问题
PHP导出MySQL数据到Excel文件(fputcsv)
php设计模式 Strategy(策略模式)
Warning: session_destroy() : Trying to destroy uninitialized sessionq错误