深入探讨如何提高PHP运行效率

开发 后端
我们在进行PHP实际编码中,需要不断的进行代码的升级,以便达到更有效的程序。下面我们就向大家介绍了有关提高PHP运行效率的一些方法。

大家都知道,PHP是一个功能强大的HTML脚本语言。但是,在实际应用中,它也跟其他计算机语言一样,具有不少的缺点。我们需要不断的更新代码,来改善程序的高效性。下面我们就介绍几点关于提高PHP运行效率的方法。

#t#提高PHP运行效率1,在函数中,传递数组时

使用 return 比使用 global 要高效

比如

 

  1. function userloginfo($usertemp){   
  2. $detail=explode("|",$usertemp);   
  3. return $detail;   
  4. }   
  5. $login=userloginfo($userdb);  

 

 

  1. function userloginfo($usertemp){   
  2. global $detail;   
  3. $detail=explode("|",$usertemp);   
  4. }   
  5. userloginfo($userdb); 

要高效

提高PHP运行效率2,(这个代码用于得到程序目录对应的网址,推荐使用)

 

  1. $urlarray=explode('/',$HTTP_
    SERVER_VARS['REQUEST_URI']);   
  2. $urlcount=count($urlarray);unset
    ($urlarray[$urlcount-1]);   
  3. $ofstarurl='http://'.
    $HTTP_SERVER_VARS['HTTP_HOST'].
    implode('/',$urlarray);  

这段代码比

 

  1. $pre_urlarray=explode('/',$HTTP_SERVER_VARS['HTTP_REFERER']);   
  2. $pre_url=array_pop($pre_urlarray); 

要高效

提高PHP运行效率3,

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

 

  1. $a=2;$b=2;  

比如

 

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

 

 

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

高效

提高PHP运行效率4,

mysql 查询时尽量使用where in 少用 limit

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

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

提高PHP运行效率5,

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

提高PHP运行效率6,

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

提高PHP运行效率7,

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

提高PHP运行效率8,

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

提高PHP运行效率9,

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

提高PHP运行效率10,

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

提高PHP运行效率11,

使用

 

  1. if($online){   
  2. $online1=$online;   
  3. setcookie('online1',$online,
    $cookietime,$ckpath,$ckdomain,$secure);   
  4. }  

 

COOKIE将马上生效

使用

 

  1. if($online)   
  2. setcookie('online1',$online,
    $cookietime,$ckpath,$ckdomain,$secure);  

 

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

提高PHP运行效率12,

使用

 

  1. $handle=fopen($filename,wb);   
  2. flock($handle,LOCK_SH);   
  3. $filedata=fread($handle,
    filesize($filename));   
  4. fclose($handle);  

 

  1. file($filename);  

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

提高PHP运行效率13,截断字符串优化函数(可避免?字符出现)

 

  1. ifunction substrs($content,$length) {   
  2. if(strlen($content)>$length){   
  3. $num=0;   
  4. for($i=0;$i<$length-3;$i++) {   
  5. if(ord($content[$i])>127)$num++;   
  6. }   
  7. $num%2==1 ? $content=substr(
    $content,0,$length-4):$
    content
    =substr($content,0,$length-3);   
  8. $content.=' ...';   
  9. }   
  10. return $content;   
  11. }   

 

比如

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

提高PHP运行效率14,程序中屏蔽大小写

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

 

提高PHP运行效率15,不使用 file();和不使用 fget();(不稳定或速度慢) 取一数组函数

  1. function openfile($filename,$method="rb")   
  2. {   
  3. $handle=@fopen($filename,$method);   
  4. @flock($handle,LOCK_SH);   
  5. @$filedata=fread($handle,filesize
    ($filename));   
  6. @fclose($handle);   
  7. $filedata=str_replace("\n","
    \n
    <ofstar:>",$filedata);   
  8. $filedb=explode("<ofstar:>",$filedata);   
  9. //array_pop($filedb);   
  10. $countcount=count($filedb);   
  11. if($filedb[$count-1]==''){unset
    ($filedb[$count-1]);}   
  12. return $filedb;   
  13. }  

 

这个函数虽然代码比较多,不过在速度和稳定性上提高PHP运行效率的优势很大!

责任编辑:曹凯 来源: 百度博客
相关推荐

2010-07-21 09:38:15

PHP缓存技术

2009-11-27 15:24:48

PHP递归效率

2009-12-07 13:55:58

PHP array_m

2009-12-07 16:07:03

PHP类的继承

2009-12-02 16:46:18

PHPMailer

2009-12-02 11:20:56

PHP命令行参数

2009-12-01 16:34:21

PHP表单

2009-12-07 19:06:20

PHP mysql_f

2009-12-23 16:13:00

WPF Attache

2010-11-22 14:18:32

MySQL锁机制

2009-11-20 17:17:08

Oracle函数索引

2021-05-17 05:36:02

CSS 文字动画技巧

2009-12-10 13:14:26

PHP下拉框

2009-12-07 11:21:59

PHP生成缩略图

2021-10-22 08:09:16

断点调试IAR开发工具

2011-02-25 09:23:00

Java类加载器

2010-03-05 13:44:00

Python序列

2009-08-27 11:27:58

foreach语句C# foreach语

2015-09-02 08:57:56

JavaHashMap工作原理

2023-01-12 17:18:06

数据库多云
点赞
收藏

51CTO技术栈公众号