php代码优化及高效提速问题的实现方法

1,在函数中,传递数组时 使用 return 比使用 global 要高效 比如

下面是phper在实际编写中,发现的一些问题,其它我们的好多代码,需要优化,很多程序都是可以再提速的

function userloginfo($usertemp){ $detail=explode(“|”,$usertemp); return
$detail; } $login=userloginfo($userdb);

一、 在函数中,传递数组时使用 return 比使用 global 要高效,比如:

function userloginfo($usertemp){

function userloginfo($usertemp){ global $detail;
$detail=explode(“|”,$usertemp); } userloginfo($userdb);

$detail=explode(“|”,$usertemp);

要高效

return $detail;

2,(这个代码用于得到程序目录对应的网址,推荐使用)

}

$urlarray=explode(/,$HTTP_SERVER_VARS[REQUEST_URI]);
$urlcount=count($urlarray);unset($urlarray[$urlcount-1]);
$ofstarurl=$HTTP_SERVER_VARS[HTTP_HOST].implode(/,$urlarray);

$login=userloginfo($userdb);

这段代码比

$pre_urlarray=explode(/,$HTTP_SERVER_VARS[HTTP_REFERER]);
$pre_url=array_pop($pre_urlarray);

function userloginfo($usertemp){

要高效

global $detail;

3,在循环中判断时,数值判断使用恒等要比等于高效 $a=2;$b=2; 比如
if($a==$b)$c=$a; 比 if($a===$b)$c=$a; 高效

$detail=explode(“|”,$usertemp);

4,mysql 查询时尽量使用where in 少用 limit limit查多记录的前几条,
速度很快, 但是查询最面几条就会慢 使用in .在查询连续性记录,非常快,
非连续性记录第一次运行会稍微慢一点,但是之后将比较快!

}

5,NT服务器数据操作稳定性不及unix/linux

userloginfo($userdb);

6,输出前使用尽量使用 ob_start();
可以加快输出速度,适用NT或nuli/linux,对unlix类服务器 如果使用
ob_start(ob_gzhandler);输出效率将更高

要高效

7,判断的时候尽量使用if($a==他的值)
否定的时候尽量使用if(empty($a)),因为这样程序运行更快速

二、 (这个代码用于得到程序目录对应的网址,推荐使用)

8,使用不等时 != 与 效率相当

$urlarray=explode(‘/’,$HTTP_SERVER_VARS[‘REQUEST_URI’]);

9,个人经验得 使用 $a=”11111111111111″; 的效率和 $a=11111111111111;
相当.并不象书本说的相差很大

$urlcount=count($urlarray);unset($urlarray[$urlcount-1]);

10,使用规范的SQL语句, 会有利于MySQL的解析

$ofstarurl=’);

11,使用

这段代码比

if($online){ $online1=$online;
setcookie(online1,$online,$cookietime,$ckpath,$ckdomain,$secure); }

$pre_urlarray=explode(‘/’,$HTTP_SERVER_VARS[‘HTTP_REFERER’]);

COOKIE将马上生效 使用

$pre_url=array_pop($pre_urlarray);

if($online)
setcookie(online1,$online,$cookietime,$ckpath,$ckdomain,$secure);

要高效

COOKIE需要再刷新一次才能生效

三、 在循环中判断时,数值判断使用恒等要比等于高效

12,使用

$a=2;$b=2;

$handle=fopen($filename,wb); flock($handle,LOCK_SH);
$filedata=fread($handle,filesize($filename)); fclose($handle);

比如

if($a==$b)$c=$a;

file($filename);

无论在速度还是稳定上都要优秀

if($a===$b)$c=$a;

13,截断字符串优化函数(可避免?字符出现)

高效

function substrs($content,$length) { if(strlen($content)$length){
$num=0; for($i=0;$i$length-3;$i++) { if(ord($content[$i])127)$num++; }
$num%2==1 ?
$content=substr($content,0,$length-4):$content=substr($content,0,$length-3);
$content.= …; } return $content; }

四、 MySQL 查询时尽量使用where in 少用 limit

比如$newarray[1]=substrs($newarray[1],25);

limit查多记录的前几条, 速度很快, 但是查询最面几条就会慢

14,程序中屏蔽大小写

使用in .在查询连续性记录,非常快,
非连续性记录第一次运行会稍微慢一点,但是之后将比较快!

for ($asc=65;$asc=90;$asc++) { //strtolower()
此函数在一些服务器会产生乱码! if (strrpos($regname,chr($asc))!==false) {
$error=”为了避免用户名混乱,用户名中禁止使用大写字母,请使用小写字母”;
$reg_check=0; } }

五、
NT服务器数据操作稳定性不及unix/Linux

15,不使用 file();和不使用 fget();(不稳定或速度慢) 取一数组函数

六、 输出前使用尽量使用 ob_start();

function openfile($filename,$method=”rb”) {
$handle=@fopen($filename,$method); @flock($handle,LOCK_SH);
@$filedata=fread($handle,filesize($filename)); @fclose($handle);
$filedata=str_replace(“”,”ofstar:”,$filedata);
$filedb=explode(“ofstar:”,$filedata); //array_pop($filedb);
$count=count($filedb);
if($filedb[$count-1]==){unset($filedb[$count-1]澳门新葡亰手机版,);} return $filedb; }
//这个函数虽然代码比较多,不过在速度和稳定性上优势很大!

可以加快输出速度,适用NT或nuli/linux,对unlix类服务器 如果使用
ob_start(‘ob_gzhandler’);输出效率将更高

先写到这
以上完全个人的一点小结,,不过正确性都经过反复测试,如果有朋友质疑,请先测试,再讨论,谢谢!

七、 判断的时候尽量使用if($a==他的值)

否定的时候尽量使用if(empty($a)),因为这样程序运行更快速

八、 使用不等时 != 与 <>效率相当

九、 个人经验得 使用 $a=”11111111111111″; 的效率和 $a=’11111111111111′;
相当.并不象书本说的相差很大

十、 使用规范的SQL语句, 会有利于MySQL的解析

十一、 使用

if($online){

$online1=$online;

setcookie(‘online1’,$online,$cookietime,$ckpath,$ckdomain,$secure);

}

COOKIE将马上生效

使用

if($online)

setcookie(‘online1’,$online,$cookietime,$ckpath,$ckdomain,$secure);

COOKIE需要再刷新一次才能生效

十二、 使用

$handle=fopen($filename,wb);

flock($handle,LOCK_SH);