加入收藏 | 设为首页 | 会员中心 | 我要投稿 我爱资讯网 (https://www.52junxun.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php代码 追求程序速度,而不是编程的速度

发布时间:2022-09-16 15:10:53 所属栏目:PHP教程 来源:
导读: 这篇文章主要讲解的是追求程序速度,而不是编程的速度,文章内容非常详细,相信一定可以解决你的问题php代码,需要的朋友可以参考下哦

  1.使用内嵌的HTML代码,而不是PHP的echo语句。

  因为PHP
       这篇文章主要讲解的是追求程序速度,而不是编程的速度,文章内容非常详细,相信一定可以解决你的问题php代码,需要的朋友可以参考下哦
 
  1.使用内嵌的HTML代码,而不是PHP的echo语句。
 
  因为PHP是一门嵌入式Web编程语言,可以将HTML代码和PHP代码相互嵌入。但是很多程序员担心在HTML代码中过多的使用""嵌入PHP代码会多次调用PHP解释器,从而降低了PHP代码的运行速度,所以宁愿使用PHP的echo语句来输出HTML代码,而不直接使用HTML代码。但事实却恰恰相反。每一个PHP页面只调用一次PHP解释器来解释所有的PHP代码,所以,只在需要时才嵌入PHP代码,而大多数的时候直接使用HTML代码输入结果,不但不会降低程序的运行速度,而且因为减少了对echo语句的解析,往往可以提高代码的运行速度。
 
  下面的一段代码证明了我们的结论。在这段代码中,我们使用了前面介绍的时间测试函数。
 
  2.使用str-replace而不是ereg-replace
 
  习惯使用Perl进行编程的程序员更加愿意使用ereg_replace完成字符串替换工作,因为在PHP中ereg_replace的用法和Perl中模式匹配的用法相近。但是,下面的这段代码证明,使用str_replace代替ereg_replace将可以大大提高代码的运行速度。
 
  测试str_replace和ereg_replace的运行速度
 
  //这段代码测试str_replace的运行速度
 
  emphasis;?>
 
  for($i=0;$istr_replace(i>,b>,$string).
 
  }
 
  //这段代码测试ereg_replace的运行速度
 
  for($i=0;$iereg_replace(,,$string).
 
  }
 
  //打印结果
 
  结论
 
  使用str_replace的时间-
 
  使用ereg_pattern的时间-
 
  运行上面的代码,得到的结果是:
 
  使用str_replace的时间-0.089757
 
  使用ereg_pattern的时间-0.248881
 
  从运行的结果我们可以看出使用str_replace替代ereg_replace作为字符串替换函数,极大地提高了代码的运行速度。
 
  3.注意字符串的引用
 
  PHP和其它很多编程语言一样,可以使用双引号("")来引用字符串,也可以使用单引号()。但是在PHP中,如果使用双引号来引用字符串,那么PHP解析器将首先分析字符串中有没有对变量的引用,有变量的话,将对变量进行替换。如果是单引号,则没有如此复杂——直接将单引号包含起来的所有字符串直接显示出来。显然,在PHP编程中,如果使用单引号引用字符串变量要比使用双引号快速一些。
 
  4.在数据库中避免使用联合操作
 
  比起其它的Web编程语言来说,PHP的数据库功能十分强大。但是在PHP中数据库的运行仍然是一件十分费时费力的事情,所以,作为一个Web程序员,要尽量减少数据库的查询操作,同时应该为数据库建立适当的索引。另一件值得注意的事情是在用PHP操作数据库时,尽可能不使用多个数据表的联合操作,尽管联合操作可以增强数据库的查询功能,但是却大大增加了服务器的负担。
 
  为了说明这个问题,我们可以看看下面的这个简单的例子。
 
  我们在数据库中创建了两个数据表foo和big_foo。在数据表foo中,只有一个字段,包含了从1-1000之间的所有自然数。数据表big_foo同样只有一个字段,但包含了从1-1,000,000之间的全部自然数。所以,从大小上说,big_foo等于foo与它自身进行了联合操作。
 
  $db->query("select*fromfoo");
 
  0.032273secs
 
  $db->next_record();
 
  0.00048999999999999secs
 
  $db->query("insertintofoovalues(NULL)");
 
  0.019506secs
 
  $db->query("select*fromfooasa,fooasb");
 
  17.280596secs
 
  $db->query("select*fromfooasa,fooasbwherea.id>b.id");
 
  14.645251secs
 
  $db->query("select*fromfooasa,fooasbwherea.id=b.id");
 
  0.041269secs
 
  $db->query("select*frombig_foo");
 
  25.393672secs
 
  从上面操作结果我们可以发现,对于两个有1000条记录的数据表进行联合,其速度并不比对一个1000000条纪录的大型数据表单独进行操作快多少。
 
  5.注意include与require的区别
 
  在PHP变成中,include()与require()的功能相同,但在用法上却有一些不同,include()是有条件包含函数,而require()则是无条件包含函数。例如在下面的一个例子中,如果变量$somgthing为真,则将包含文件somefile:
 
  if($something){
 
  include("somefile");
 
  }
 
  但不管$something取何值,下面的代码将把文件somefile包含进文件里:
 
  if($something){
 
  require("somefile");
 
  }
 
  下面的这个有趣的例子充分说明了这两个函数之间的不同。
 
  $i=1;
 
  while($i
 

(编辑:我爱资讯网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!