1,在函数中,传递数组时
使用 return 比使用 global 要高效
比如
function urloginfo($urtemp){
$detail=explode(“|”,$urtemp);
return $detail;
}
$login=urloginfo($urdb);
比
function urloginfo($urtemp){
global $detail;
$detail=explode(“|”,$urtemp);
}
urloginfo($urdb);
要高效
2,(这个代码用于得到程序目录对应的网址,推荐使用)
$urlarray=explode(‘/’,$http_rver_vars[‘request_uri’]);
$urlcount=count($urlarray);unt($urlar鲁智深的结局ray[$urlcount-1]);
$ofstarurl=’http://’.$http_rver_vars[‘http_host’].implode(‘/’,$urlarray);
这段代码比
$pre_urlarray=explode(‘/’,$http_rver_vars[‘http_referer’]);
$pre_url=array_pop($pre_urlarray);
要高效
3,在循环中判断时,数值判断使用恒等要比等于高效
$a=2;$b=2;
比如
if($a==$b)$c=$a;
比
if($a===$b)$c=$a;
高效
4,mysql 查询时尽量使用where in 少用 limit
limit查多记录的阿克奥斯前几条, 速度很快, 但是查询最面几条就会慢
使用in .在查询连续性记录,非常快, 非连续性记录第一次运行会稍微慢一点,但是之后将比较快!
5,nt服务器数据操作稳定性不及unix/linux
6,输出前使用尽量使用 ob_start(); 可以加快输出速度,适用nt或nuli/linux,对unlix类服务器 如果使用 ob_st铁路乘务员招生art(‘ob_gzhandler’);输出效率将更高
7,判断的时候尽量使用if($a==他的值) 否定的时候尽量使用if(empty($a)),因为这样程序运行更快速
8,使用不等时 != 与 <> 效率相当
9,个人经验得 使用 $a=”11111111111111″; 的效率和 $a=’11111111111111′; 相当.并不象书本说的相差很大
10,使用规范的sql语句, 会有利于mysql的解析
11,使用
if($online){
$online1=$online;
tcookie(‘online1’,$online,$cookietime,$ckpath,$ckdomain,$cure);
}
cookie将马上生效
使用
if($online)
tcookie(‘online1’,$online,$cookietime,$ckpath,$ckdomain,$cure);
cookie需要再刷新一次才能生效
12,使用
$handle=fopen($filename,wb);
flock($handle,lock_sh);
$filedata=fread($handle,filesize($filename));
fclo($handle);
比
file($filename);
无论在速度还是稳定上都要优秀
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;
}
比如$newarray[1]=substrs($newarray[1],25);
14,程序中屏蔽大小写
for ($asc=65;$asc<=90;$asc++)
{ //strtolower() 此函数在一些服务器会产生乱码!
if (strrpos($regname,chr($asc))!==fal)
{
$error=”为了避免用户名混乱,用户名中禁止使用大写字母,请使用小写字母”;
$reg_check=0;
}
}
15,不使用 file();和不使用 fget();(不稳定或速度慢) 取一数组函数
function openfile($filename,$method=”rb”)
{
$handle=@fopen($filename,$method);
@flock($handle,lock_sh);
@$filedata=fread($handle,filesize($filename));
@fclo($handle);
$filedata=str_replace(“\n”,”\n<ofstar:>”,$filedata);
$filedb=explode(“<ofstar:>”,$filedata);
//array_pop($filedb);
$count=count($filedb);
if($filedb[$count-1]==”){unt($filedb[$count-1]);}
return $filedb;
}
//这个函数虽然代码比较多,不过在速度和稳定性上优势很大!
先写到这
以上完全个人的一点小结,,不过正确性都经过反复测试,如果有朋友质疑,请先测试,再讨论,谢谢!
本文发布于:2023-04-06 07:22:18,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/0e09148b323e6286bd0622e5f60d1e55.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:php代码优化及php相关问题总结.doc
本文 PDF 下载地址:php代码优化及php相关问题总结.pdf
留言与评论(共有 0 条评论) |