Home  >  Article  >  Backend Development  >  Introduction to PEAR: Use PEAR to write your next PHP program_PHP Tutorial

Introduction to PEAR: Use PEAR to write your next PHP program_PHP Tutorial

WBOY
WBOYOriginal
2016-07-13 17:36:45809browse

pear简介:用pear来写你的下一个php程序 

 
内容:

什么是pear
为什么要使用pear?
pear能给我带来什么好处?
pear的编码规则
开始使用pear
总结
相关资源
作者简介


潘凡(night sailer) (nightsailer@hotmail.com)
北京赛迪网信息技术有限公司
2001 年 6 月
你可能已经是个php的老手了,写了很多非常棒的代码。但是,如果你现在要把它们加入到你现在的项目中去,是否有些吃力?你的朋友想使用你的代码作为他的项目中的一个模块,但是你发现你们使用了截然不同的编码风格,让他适应,甚至不如重写一个!
请跟我来,使用pear标准编写你的php程序吧,你的程序将会拥有更大的活力,你的程序和代码将会很方便地和其他高手的代码融合在一起,pear就象cpan对于perl一样,会让php产生更高的能量。
什么是pear
pear是php扩展与应用库(the php extension and application repository)的缩写。它是一个php扩展及应用的一个代码仓库,简单地说,pear就是php的cpan。
为什么要使用pear?
php是一个非常优秀的脚本语言,简洁、高效,随着4.0的发布,越来越多的人使用它来进行动态网站的开发,可以说,php已经成为最优秀的internet开发语言之一,尤其对于那些需要能够快速、高效地开发中小规模的商业应用的网站开发人员,php是其首选的语言。但是随着php的应用的不断增多,对于这些应用缺乏统一的标准和有效的管理,因此,php社区很难象perl社区的人们那样方便的共享彼此的代码和应用,因为php缺乏象cpan那样的统一的代码库来分类管理应用的代码模块(熟悉perl的人都知道,cpan是一个巨大的perl的扩展模块仓库,编写的应用模块可以放在cpan下面的适当的分类目录下面,其他的人可以很方便地复用,当然,你编写应用模块时候也需要遵守其中的准则。)
为此,pear就应运而生了,并且从4.04开始,随着php核心一起被分发。
pear能给我带来什么好处?
1.如前所述,pear按照一定的分类来管理pear应用代码库,你的pear代码可以组织到其中适当的目录中,其他的人可以方便地检索并分享到你的成果。
2.pear不仅仅是一个代码仓库,它同时也是一个标准,使用这个标准来书写你的php代码,将会增强你的程序的可读性,复用性,减少出错的几率。
3.pear通过提供2个类为你搭建了一个框架,实现了诸如析构函数,错误捕获功能,你通过继承就可以使用这些功能。
pear的编码规则
pear的编码规则包括缩进规则,控制结构,函数调用,函数定义,注释,包含代码,php标记,文件头的注释块,cvs标记,url样例,常量的命名这11方面。下面简要地介绍一下:
缩进规则:
pear中需要使用4个空格来缩排代码,并且不使用tab。如果你使用vim,将下列设置放入你的~/.vimrc中:
set expandtab
set shiftwidth=4
set tabstop=4

如果,你使用emacs/xemacs,需要把indent-tabs-mode 设置成nil。
不过你象我一样喜欢用(x)emacs编辑php文件,我强烈推荐你安装php-mode,这样当你编写pear代码的时候,它会自动调整你的缩排风格,当然php-mode还有许多很优秀的特性,你可以从资源列表中的地方下载最新版的php-mode。
控制结构:
这里所说的控制结构包括: if for while switch 等。对于控制结构,在关键字(如if for ..)后面要空一个格,然后再跟控制的圆括号,这样,不至于和函数调用混淆,此外,你应该尽量完整的使用花括号{},即使从语法上来说是可选的。这样可以防止你以后需添加新的代码行时产生逻辑上的疑惑或者错误。这里是一个样例:
if ((条件1) && (条件2)) {
语句1;
}esleif ((条件3) || (条件4)) {
语句2;
}else {
语句3;
}


函数调用:
对于函数调用,函数名和左括号( 之间不应该有空格,对于函数参数,在分隔的逗号和下一个参数之间要有相同的空格分离,最后一个参数和右括号之间不能有空格。下面是一个标准的函数调用;
$result = foo($param1, $param2, $param3);
不规范的写法:
$result=foo ($param1,$param2,$param3);
$result=foo( $param1,$param2, $param3 );


此外,如果要将函数的返回结果赋值,那么在等号和所赋值的变量之间要有空格,同时,如果是一系列相关的赋值语句,你添加适当的空格,使它们对齐,就象这样:
$result1 = $foo($param1, $param2, $param3);
$var2 = $foo($param3);
$var3 = $foo($param4, $param5);


函数定义:
函数定义遵循"one true brace"习俗:
function connect(&$dsn, $persistent = false)
{
if (is_array($dsn)) {
$dsninfo = &$dsn;
} else {
$dsninfo = db::parsedsn($dsn);
}
if (!$dsninfo || !$dsninfo[phptype]) {
return $this->raiseerror();
}
return true;
}

如上所示,可选参数要在参数表的末端,并且总是尽量返回有意义的函数值。
关于注释:
对于类的在线文档,应该能够被phpdoc转换,就象javadoc那样。phpdoc也是一个pear的应用程序,更详细的介绍你可以去http://www.phpdoc.de/查看。除了类的在线文档,建议你应该使用非文档性质的注释来诠释你的代码,当你看到一段代码时想:哦,我想不需要在文档里去仔细描述它吧。那么你最好给这段代码作一个简单的注释,这样防止你会忘记它们是如何工作的。对于注释的形式,c的 /* */和c++的//都不错,不过,不要使用perl或者shell的#注释方式。
包含代码:
无论什么时候,当你需要无条件包含进一个class文件,你必须使用requre_once;当你需要条件包含进一个class文件,你必须使用include_once;这样可以保证你要包含的文件只会包含一次,并且这2个语句共用同一个文件列表,所以你无须担心二者会混淆,一旦require_once 包含了一个文件,include_once不会再重复包含相同的文件,反之亦然。
php代码标记:
任何时候都要使用定义你的php代码,而不要简单地使用,这样可以保证pear的兼容性,也利于跨平台的移植。
文件头的注释声明:
所有需要包含在pear核心发布的php代码文件,在文件开始的时候,你必须加入以下的注释声明:
/* vim: set expandtab tabstop=4 shiftwidth=4: */
// +----------------------------------------------------------------------+
// | php version 4.0 |
// +----------------------------------------------------------------------+
// | copyright (c) 1997, 1998, 1999, 2000, 2001 the php group  |
// +----------------------------------------------------------------------+
// | this source file is subject to version 2.0 of the php license,  |
// | that is bundled with this package in the file license, and is |
// | available at through the world-wide-web at  |
// |http://www.php.net/license/2_02.txt.  |
// | if you did not receive a copy of the php license and are unable to  |
// | obtain it through the world-wide-web, please send a note to |
// |license@php.netso we can mail you a copy immediately.  |
// +----------------------------------------------------------------------+
// | authors: original author  |
// | your name |
// +----------------------------------------------------------------------+
//
// $id$

对于不在pear核心代码库中的文件,建议你也在文件的开始处有这样一个类似的注释块,标明版权,协议,作者等等。同时也在第一行加入vim的modeline,这样在vim中能够保持pear的代码风格。
cvs标记:
如上面所展示那样,在每个文件中加入cvs的id标记,如果你编辑或修改的文件中没有这个标记,那么请加入,或者是替换原文件中相类似的表现形式(如"last modified"等等)
url样本:
你可以参照rfc 2606,使用"http://www.example.com"作为所有的url样本。
常量命名:
常量应该尽量使用大写,为了便于理解,使用下划线分割每个单词。同时,你应该常量所在的包名或者是类名作为前缀。比如,对于bug类中常量应该以bug_开始。以上是pear的编码规则,详细的编码规则可以参考pear中的coding_standdard文件的说明。为了更好地理解这些编码规则,你也可以参考一下现有pear核心模块的代码。
开始使用pear
pear
使用pear很简单,你只需这样定义你自己的pear程序:
require_once "pear.php";
class your_class_name extends pear{
你的类定义...
}


Of course, you need to abide by the pear coding rules mentioned above, and then you can implement what you want to do inside your class. Next, let’s discuss it. In fact, pear provides us with 2 predefined classes:
pear: This is the base class of pear, and all pear extensions must inherit and derive from it.
pear_error: The base class of pear error handling. You can choose to derive your own error handling class.
Generally speaking, you should not create an instance of pear directly, but derive a new class yourself, and then create an instance of this new class. As a base class, pear provides us with some useful functions, the most important of which are destructors and error handling
Destructor
PHP supports constructors, but does not support destructors. However, PHP provides The function register_shutdown_function() can call back the registered function before the script terminates, so pear uses this feature to provide simulation of the destructor. If you have a subclass of pear, called mypear, then in mype

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/486627.htmlTechArticlePear introduction: Use pear to write your next PHP program content: What is pスススススpススWhy use pススス? What benefits can pear bring to me? Coding rules for ススス...

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn