快速业务通道

优秀的PHP开发者是怎样炼成的?

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-22
运行速度 emphasis; ?>

  for ($i=0; $i<1000; $i++) {

  str_replace(i>, b>, $string).

  ;

  }

  ?>

  //这段代码测试ereg_replace的运行速度

  for ($i=0; $i<1000; $i++) {

  ereg_replace(<([/]*)i>, <\\1b>, $string).

  ;

  }

  ?>

 

  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 * from foo\");

  0.032273 secs

  $db->next_record();

  0.00048999999999999 secs

  $db->query(\"insert into foo values (NULL)\");

  0.019506 secs

  $db->query(\"select * from foo as a, foo as b\");

  17.280596 secs

  $db->query(\"select * from foo as a, foo as b where a.id > b.id\");

  14.645251 secs

  $db->query(\"select * from foo as a, foo as b where a.id = b.id\");

  0.041269 secs

  $db->query(\"select * from big_foo\");

  25.393672 secs

 

  从上面操作结果我们可以发现,对于两个有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 < 3) { require(\"somefile.$i\"); $i++; }

 

  在这段代码中,每一次循环的时候,程序都将把同一个文件包含进去。很显然这不是程序员的初衷,从代码中我们可以看出这段代码希望在每次循环时,将不同的文件包含进来。如果要完成这个功能,必须求助函数include();

 

  $i = 1; while ($i < 3) { include(\"s

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号