目錄 一,什么是PEAR與Benchmark 二,性能比較代碼準(zhǔn)備與調(diào)試 三,性能比較測(cè)試結(jié)果 四,性能比較測(cè)試總結(jié) 五,附性能比較源代碼下載

一,什么是PEAR與Benchmark

請(qǐng)參考PHP性能 " /> 81精品国产乱码久久久久久,欧美日韩不卡一区二区,欧美gay囗交囗交

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

PHPWind與Discuz截取字符函數(shù)substrs與cutstr性能比較

以掌握使用Benchmark_Iterate類(lèi)工具的方法。

目錄
一,什么是PEAR與Benchmark
二,性能比較代碼準(zhǔn)備與調(diào)試
三,性能比較測(cè)試結(jié)果
四,性能比較測(cè)試總結(jié)
五,附性能比較源代碼下載

一,什么是PEAR與Benchmark

請(qǐng)參考php性能優(yōu)化系列
第二期 php性能優(yōu)化工具篇Benchmark類(lèi)調(diào)試執(zhí)行時(shí)間
第一期 php性能優(yōu)化準(zhǔn)備篇圖解PEAR安裝

二,性能比較代碼準(zhǔn)備與調(diào)試

測(cè)試環(huán)境說(shuō)明
操作系統(tǒng):Windows xp Service Pack 3
php版本:php Version 5.2.11
Apache版本:Apache 2.0 Handler

第一步,下載phpwind與discuz!程序源代碼
1,下載 phpwind v7.5sp3 論壇版 安裝包:簡(jiǎn)體 GBK
2,下載 Discuz! 7.2_FULL(含UCenter) 簡(jiǎn)體GBK

第二步,分別獲取兩個(gè)程序的截取字符函數(shù)substrs()和cutstr(),其中phpWind截取字符函數(shù)substrs()由兩個(gè)函數(shù)組成,分別是substrs與utf8_trim函數(shù)。
復(fù)制代碼 代碼如下:
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;
}

第三步,編寫(xiě)使用PEAR Benchmark_Iterate類(lèi)調(diào)試的代碼
復(fù)制代碼 代碼如下:
<?php
require_once "Benchmark/Iterate.php";
$bench = new Benchmark_Iterate;
$charset = $GLOBALS['db_charset'] = 'gbk';//utf-8
$content = "今年春晚,我特地關(guān)注了趙本山的新小品《捐助》,這篇小品對(duì)弱勢(shì)群體的不尊重并無(wú)改變,小品講的是趙本山與其弟子扮演兩個(gè)捐助者...";

/*phpwind*/
$bench->run(50,"substrs",$content,30);
/*discuz*/
//$bench->run(50,"cutstr",$content,30);

$result = $bench->get();
?>

分別切換substrs和cutstr兩個(gè)函數(shù)并且調(diào)用50次獲取兩個(gè)函數(shù)執(zhí)行的平均時(shí)間。
三,性能比較測(cè)試結(jié)果

1,phpWind程序substrs函數(shù)當(dāng)截取字符編碼為GBK的情況
<aphpWind程序substrs函數(shù)當(dāng)截取字符編碼為GBK的情況 src="/d/file/itjie/phpjishu/2014-10-22/05faab0fc262317b670648b0e24cc8b5.png">
圖解phpWind程序substrs函數(shù)截取GBK編碼的字符平均時(shí)間在0.0014s-0.0015s之間,縱坐標(biāo)表示執(zhí)行的時(shí)間,橫坐標(biāo)表示執(zhí)行的次數(shù),圖表中mean表示平均執(zhí)行時(shí)間,注s表示秒

2,Discuz!程序cutstr函數(shù)當(dāng)截取字符編碼為GBK的情況
Discuz!程序cutstr函數(shù)當(dāng)截取字符編碼為GBK的情況

圖解:Discuz!程序cutstr函數(shù)截取GBK編碼的字符平均時(shí)間在0.0016s-0.0018s之間

3,phpWind程序substrs函數(shù)當(dāng)截取字符編碼為UTF-8的情況
<aphpWind程序substrs函數(shù)當(dāng)截取字符編碼為UTF-8的情況 src="/d/file/itjie/phpjishu/2014-10-22/6e994bd5a74aac0510226c91f9902cae.png">

圖解phpWind程序substrs函數(shù)截取UTF-8編碼的字符平均時(shí)間在0.001s-0.0012s之間

4,Discuz!程序cutstr函數(shù)當(dāng)截取字符編碼為UTF-8的情況
Discuz!程序cutstr函數(shù)當(dāng)截取字符編碼為UTF-8的情況
圖解:Discuz!程序cutstr函數(shù)截取UTF-8編碼的字符平均時(shí)間在0.0044s-0.0052s之間

四,性能比較測(cè)試總結(jié)

如上使用PEAR的Benchmark_Iterate類(lèi)比較了兩個(gè)截取字符函數(shù)的執(zhí)行性能,在實(shí)際的代碼開(kāi)發(fā)過(guò)程中,為了保證代碼的效率與性能,我們可以采取同樣的方法來(lái)分析函數(shù)的執(zhí)行性能或問(wèn)題,這個(gè)非常有用!

本文通過(guò)比較phpWind與Discuz兩個(gè)社區(qū)論壇產(chǎn)品的截取字符函數(shù)substrs與cutstr的執(zhí)行性能情況為例,談?wù)凱EAR Benchmark_Iterate類(lèi)在實(shí)際開(kāi)發(fā)中的應(yīng)用,請(qǐng)繼續(xù)關(guān)注下期的php性能優(yōu)化系列。

php技術(shù)PHPWind與Discuz截取字符函數(shù)substrs與cutstr性能比較,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 定州市| 台湾省| 申扎县| 江源县| 永城市| 鄂温| 南召县| 綦江县| 北川| 沅陵县| 崇明县| 文安县| 诸暨市| 建德市| 雷州市| 钦州市| 陇南市| 麻江县| 通海县| 普宁市| 亳州市| 华亭县| 元阳县| 洛阳市| 行唐县| 桃源县| 日喀则市| 开封市| 广宗县| 谷城县| 丘北县| 富顺县| 东城区| 屏东县| 河北区| 湘潭市| 汕头市| 台北县| 思茅市| 桦甸市| 都匀市|