PHP头条
热点:

PHP 高手之路(三)


使用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; $i<1000; $i++) {
  str_replace(i>, b>, $string).
;
  }
  ?>
   
  //这段代码测试ereg_replace的运行速度
   


   
    for ($i=0; $i<1000; $i++) {
  ereg_replace(<([/]*)i>, <\1b>, $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 * 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

www.phpzy.comtrue/phprm/31661.htmlTechArticlePHP 高手之路(三) 使用str-replace而不是ereg-replace 习惯使用Perl进行编程的程序员更加愿意使用ereg_replace完成字符串替换工作,因为在php (做为现在的主流开发语言) 中ereg_replace的用法...

相关文章

    暂无相关文章

PHP之友评论

今天推荐