三个准则教你成为PHP编程高手_PHP教程

编辑Tag赚U币
教程Tag:暂无Tag,欢迎添加,赚取U币!

推荐:解读使用PHP与XML进行网站编程
一、HTML的局限性分析 1.HTML的可扩展性差。虽然作为一般的应用,HTML应经够用了,但是在处理数学和化学等符号时,HTML有明显的缺点,而且它无法进行扩展,这样使它的发展收到了极大的限制。 2.链路丢失后不能自动纠正。由于Web页面的URL地址经常改变,而在

PHP是一门高效的网络编程语言,由于他具有编写灵活、运行快速等好处,迅速成为Web程式员的最佳选择语言。前不久的一份权威调查表明,目前已有31.6%的网站使用PHP作为主要的服务器端编程语言。

不过,要成为一名PHP编程高手却并不容易。并不像非常多人想象的那样,只要能够飞快地编写几条简单的代码去解决一个复杂的问题就是PHP编程高手了,真正的PHP高手还需要考虑更多的其他问题。以下三条准则是一名成熟的PHP程式员在编程中应该首先遵循的准则。

1.懒惰是金
2.编写漂亮的代码
3.追求程式的速度,而不是编程的速度

一、懒惰是金

做一个懒惰的程式员吗?这个想法太奇怪了!因为这个世界上最忙碌的人可能就是计算机程式员了。但正是因为程式员太忙了,所以才应该在编程时学会偷懒。

对于一个程式员来说,懒惰的方法有两种:其一,大胆使用现成的别人的程式代码,把这些代码融入到你自己的程式或项目中去。其二是编写一些有用的代码建立一个函数库,在将来编写程式时能顺手拈来,省去了许多重复的劳动,自然就能懒惰一点了。

这两种偷懒的方法都非常适合PHP程式员了。

首先,PHP是在自由开放的环境中诞生和成长的一门语言。在世界各地,有成千上万的程式员,他们一直在为PHP的完美而不断奋斗,他们也愿意和别人分享自己的聪明才智和自己编写的代码。你每天都能从一些PHP网站、邮件列表、新闻组发现大量的优秀的程式代码。这样说,我并不是鼓励你整天等着让别人为你编写代码,不过你能“站在伟人的肩膀上”,充分发扬“拿来主义”,聪明地应用别人的程式代码能节省你大量时间。其次,在PHP中,你能方便地建立自己的函数库,这样能在你以后编写程式时省去非常多麻烦。

下面笔者为大家介绍几个通用的函数,这些函数有的来自网上的一些开放原始码的项目,有的精选自邮件列表。如果你能把他们加入到你自己的函数库中,迟早你将会发现自己受益无穷。

1.通用数据库处理函数

和其他的CGI函数相比,PHP的好处之一是具有非常强大的数据库处理能力。不过,在PHP中,对于不同的数据库都使用一些特定的函数来专门处理,缺少通用的数据库处理函数。这大大降低了程式代码的可移植性,这也为初学编程的朋友带来了非常多不便。

在网上,许多程式员都通过封装类解决了这个问题。他们编写了统一的函数用来处理所有流行的数据库??不管是在Linux世界深受欢迎的Mysql还是在视窗系统平台上广泛流行的SqlServer。就笔者个人来说,非常喜欢使用这些函数,因为能直接使用一些简单的诸如"query"、"next_record"之类的函数,而不必考虑数据库的连接、数据库句柄这些复杂的东西,更不必考虑使用的是何种数据库。

2.变量调试函数

PHP程式的调试一直是一件让人头疼的事,他既不像VB等高级语言那样有集成的编译调试环境,也不想Perl那样能在Linux或DOS环境下直接运行。其实,我们完万能通过灵活地使用echo语句来完成对PHP的调试工作。

下面的几个函数能让你随时查看程式中所有变量的类型及其值。

function ss_array_as_string (&$array, $column = 0) {
$str = "Array(
n";
while(list($var, $val) = each($array)){
for ($i = 0; $i < $column+1; $i++){
$str .= "&nbsp;&nbsp;&nbsp;&nbsp;";
}
$str .= $var. ==> ;
$str .= ss_as_string($val, $column+1)."
n";
}
for ($i = 0; $i < $column; $i++){
$str .= "&nbsp;&nbsp;&nbsp;&nbsp;";
}
return $str.);
}
function ss_object_as_string (&$object, $column = 0) {
if (empty($object->classname)) {
return "$object";
}
else {
$str = $object->classname."(
n";
while (list(,$var) = each($object->persistent_slots)) {
for ($i = 0; $i < $column; $i++){
$str .= "&nbsp;&nbsp;&nbsp;&nbsp;";
}
global $$var;
$str .= $var. ==> ;
$str .= ss_as_string($$var, column+1)."
n";
}
for ($i = 0; $i < $column; $i++){
$str .= "&nbsp;&nbsp;&nbsp;&nbsp;";
}
return $str.);
}
}
function ss_as_string (&$thing, $column = 0) {
if (is_object($thing)) {
return ss_object_as_string($thing, $column);
}
elseif (is_array($thing)) {
return ss_array_as_string($thing, $column);
}
elseif (is_double($thing)) {
return "Double(".$thing.")";
}
elseif (is_long($thing)) {
return "Long(".$thing.")";
}
elseif (is_string($thing)) {
return "String(".$thing.")";
}
else {
return "Unknown(".$thing.")";
}
}

需要的时候,在程式中简单地加入下面的一条代码即可查看程式中的所使用的变量(包括数组和对象)的类型和值:

echo ss_as_string($my_variable);

使用下面的语句,我们能直接查看程式中所有的变量的值:

echo ss_as_string($GLOBALS);

3. 控制Log信息的函数

调试PHP程式的另外一种重要的方法就是查看Log信息。如果能够方便地控制Log信息的级别及Log信息的显示内容,将会给程式调试带来更多的便利。下面的几个函数能方便地实现这个功能。

$ss_log_level = 0;
$ss_log_filename = /tmp/ss-log;
$ss_log_levels = array(
NONE => 0,
ERROR => 1,
INFO => 2,
DEBUG => 3);
function ss_log_set_level ($level = ERROR) {
global $ss_log_level;
$ss_log_level = $level;
}
function ss_log ($level, $message) {
global $ss_log_level, $ss-log-filename;
if ($ss_log_levels[$ss_log_level] < $ss_log_levels[$level]) {
// 不显示Log信息
return false;
}
$fd = fopen($ss_log_filename, "a+");
fputs($fd, $level. - [.ss_timestamp_pretty().] - .$message."n");
fclose($fd);
return true;
}
function ss_log_reset () {
global $ss_log_filename;
@unlink($ss_log_filename);
}

在上面的函数中,有四个Log级别变量。运行PHP程式时,只有当Log的级别低于预设的级别值时,Log信息才能被记录和显示出来。例如,在程式中加入如下的一条语句:

ss_log_set_level(INFO);

那么,运行PHP程式时,只有ERROR和INFO级别的LOG信息才能被记录和显示出来,DEBUG级的信息则被忽略了。除此之外,我们还能设定显示的信息内容,其语句如下:

ss_log(ERROR, "testing level ERROR");
ss_log(INFO, "testing level INFO");
ss_log(DEBUG, "testing level DEBUG");

你也能随时使用下面的语句清空LOG信息:

ss_log_reset();

4.速度测试函数

为了优化代码,我们需要一种能测试代码运行时间的方法,从而来选择最优的代码。下面的函数能测试运行代码所需的时间:

function ss_timing_start ($name = default) {
global $ss_timing_start_times;
$ss_timing_start_times[$name] = explode( , microtime());
}
function ss_timing_stop ($name = default) {
global $ss_timing_stop_times;
$ss_timing_stop_times[$name] = explode(, microtime());
}
function ss_timing_current ($name = default) {
global $ss_timing_start_times, $ss_timing_stop_times;
if (!isset($ss_timing_start_times[$name])) {
return 0;
}
if (!isset($ss_timing_stop_times[$name])) {
$stop_time = explode(, microtime());
}
else {
$stop_time = $ss_timing_stop_times[$name];
}
$current = $stop_time[1] - $ss_timing_start_times[$name][1];
$current += $stop_time[0] - $ss_timing_start_times[$name][0];
return $current;
}

目前能轻松地检查所有一段代码的执行时间了,甚至我们能同时使用多个计时器,只需在使用上述的几个函数时设定不同的参数作为计时器的名称就能了。

5.调试和优化数据库的操作

对于数据库来说,运行速度是至关重要的。尽管非常多书籍和文章都讲授了一些快速运行数据库的方法,不过所有的方法都必须经过实践的检验。下面我们将把PHPLib函数库中的query()函数和上面介绍的几个函数综合起来编写成新的query()函数,和原先的函数相比,这个函数增加了运行时间的监测功能。

function query($Query_String, $halt_on_error = 1) {
$this->connect();
ss_timing_start();
$this->Query_ID = @mysql_query($Query_String,$this->Link_ID);
ss_timing_stop();
ss_log(INFO, ss_timing_current(). Secs - .$Query_String);
$this->Row = 0;
$this->Errno = mysql_errno();
$this->Error = mysql_error();
if ($halt_on_error && !$this->Query_ID) {
$this->halt("Invalid SQL: ".$Query_String);
}
return $this->Query_ID;
}

二、编写漂亮的代码

1.将后台程式和前端程式分开

在编写PHP程式时,有些代码是用来处理一些事务,例如操作数据库、进行数学运算等,而另外的一些代码则只是事务处理的结果显示出来,例如一些使用echo语句将结果以HTML的格式显示在Web浏览器上的PHP代码及那些直接嵌入PHP程式的HTML代码。首先我们应该清晰地区分这两种代码,把前者称为后台程式,把后者称为前端程式。

因为PHP是一种嵌入式编程语言,也就是说,所有的PHP代码都能嵌入到HTML代码之中,这为程式的编写带来了许多便利之处。不过,“物极必反”,如果在一段较长的程式中将PHP代码和HTML代码混合编写,这将使程式杂乱无章,不利于程式的维护和阅读。所以我们需要尽可能地将这些程式中混杂于HTML代码中的PHP代码移植出来,在专门的文件中将这些代码封装成函数,然后在HTML代码中使用include语句来包含这些文件,在适当的位置调用这些函数即可。

这种做法一方面使HTML代码和PHP代码都简单易读,另一方面因为HTML代码需要不断更新,而这种分离的方法能确保后台程式不会被破坏。

同前端程式不同,后台程式更多追求的是稳定、结构化,极少更改,所以应该认真地设计和管理。其实,在设计台程式时,投入大量时间是值得的,“目前栽树,以后乘凉”,在以后的设计工作中将能轻松地使用目前编写的后台程式。

2.灵活使用包含文件

正如前面所说的那样,后台程式应当安排在一系列的包含文件中。包含文件能通过include语句在需要时动态装入,也能在php.ini文件中通过使用auto_prepend_file指令预先自动装入。

如果使用后一种方法的话,虽然取得了一劳永逸的好处,不过也有一些缺点值得我们注意。下面的一段代码向我们展示了解析一个庞大的包含文件需要一定的时间:

require(timing.inc);
ss_timing_start();
include(test.inc);
ss_timing_stop();
echo
.ss_timing_current().
;
?>

在上面的代码中,test.inc是个1000行的包含文件,运行的结果显示,解析这个包含文件花费了0.6秒钟,对于一个大型网站来说,这个速度并不是能忽略不记的。

使用包含文件的另外一个缺点是:如果一个文件中的一个语句发生错误,将会使整个网站的PHP程式都无法运行。所以使用起来也及其小心。

其实,对包含文件稍做处理,即能使包含文件只在需要时进行解析。下面的代码使abc.inc文件只在程式需要时才作解析:

if ( defined( __LIBA_INC) ) return;
define( __LIBA_INC, 1 );
/*
* 代码...
*/
?>

3.使用面向对象的编程方法

PHP也是一种面向对象的语言,面向对象的编程方法是优秀的程式员们非常推崇的一种软件设计方法,在PHP编程中能充分发挥面向对象语言的优势,对编程中的对象进行封装。在前面的代码中,我们使用了面向对象的方法,例如在管理数据库时,我们将query()函数封装进数据库类中,这极大地方便了代码的管理,增加了程式的可读性。

三、追求程式速度,而不是编程的速度

在网站建设中,程式运行速度和网页下载速度都是关系成败的重要因素。作为一名Web程式员,应该更加注意代码的运行速度。下面介绍的几种方法都在不同程度上提高了代码的运行速度。

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

因为PHP是一门嵌入式Web编程语言,能将HTML代码和PHP代码相互嵌入。不过非常多程式员担心在HTML代码中过多的使用""嵌入PHP代码会多次调用PHP解释器,从而降低了PHP代码的运行速度,所以宁愿使用PHP的echo语句来输出HTML代码,而不直接使用HTML代码。但事实却恰恰相反。每一个PHP页面只调用一次PHP解释器来解释所有的PHP代码,所以,只在需要时才嵌入PHP代码,而大多数的时候直接使用HTML代码输入结果,不仅不会降低程式的运行速度,而且因为减少了对echo语句的解析,往往能提高代码的运行速度。

下面的一段代码证实了我们的结论。在这段代码中,我们使用了前面介绍的时间测试函数。

使用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

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

6.注意echo和print的差别

PHP中echo和print的功能也基本相同,不过两者之间也有细微差别。在PHP代码中能把print作为一个普通函数来使用,例如执行下面的代码后变量$res的值将为1。

$ret = print "Hello World";

这意味着print可用在一些复杂的表达式中,而echo则不行。同样,在代码中echo语句的运行速度要略微快于print语句,因为echo语句不需求返回所有数值.


分享:xml php动态载入与分页
这是在看太平洋网的评论时看到的,太平洋网是用jsp做为后台语言,用来产生xml文件.然后在把数据绑定到html上的.我就用php也做了一个以下是源文件. -----------------xml.htm------------------ E HTML PUBLIC -//W3C//DTD HTML 4.01 Transitional/

来源:模板无忧//所属分类:PHP教程/更新时间:2009-07-12
相关PHP教程