WEB开发网
开发学院WEB开发PHP 教你如何成为PHP高手 阅读

教你如何成为PHP高手

 2010-11-29 07:22:40 来源:WEB开发网   
核心提示:for ($i=0; $i<1000; $i++) { str_replace(i>, b>, $string). ; } //这段代码测试ereg_replace的运行速度 for ($i=0; $i<1000; $i++) { ereg_replace(<([/]*)i>, &l

    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的区别

上一页  1 2 3 4 5 6 7  下一页

Tags:如何 成为 PHP

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接