ホームページ  >  記事  >  バックエンド開発  >  特制大型PHP项目的方法

特制大型PHP项目的方法

WBOY
WBOYオリジナル
2016-06-13 11:54:58860ブラウズ

研发大型PHP项目的方法

<p style="zoom:1; margin-top:15px; margin-bottom:15px; padding-top:0px; padding-bottom:0px; text-indent:2em">这篇文章介绍了在php中的面向对象编程(oop,object oriented programming)。我将向你演示怎么通过使用一些oop的概念和php的技巧来减少编码和提高质量。祝你好运! <br style="zoom:1"><br style="zoom:1">面向对象编程的概念: <br style="zoom:1">不同的作者之间说法可能不相同,不过一个oop语言必须有以下几方面: <br style="zoom:1"><br style="zoom:1">抽象数据类型和信息封装 <br style="zoom:1">继承 <br style="zoom:1">多态 <br style="zoom:1"><br style="zoom:1">在php中是通过类来完成封装的: ---------------------------------------------------<?php <br style="zoom:1">class something { <br style="zoom:1">// 在oop类中,通常第一个字符为大写 <br style="zoom:1">var $x; <br style="zoom:1">function setx($v) { <br style="zoom:1">// 方法开始为小写单词,然后使用大写字母来分隔单词,例如getvalueofarea() <br style="zoom:1">$this->x=$v; <br style="zoom:1">} <br style="zoom:1">function getx() { <br style="zoom:1">return $this->x; <br style="zoom:1">} <br style="zoom:1">} <br style="zoom:1">?>--------------------------------------------------- <br style="zoom:1"><br style="zoom:1">  当然你能按自已的喜好进行定义,但最佳保持一种标准,这样会更有效。 <br style="zoom:1"><br style="zoom:1">  数据成员在类中使用"var"声明来定义,在给数据成员赋值之前,他们是没有类型的。一个数据成员可 <br style="zoom:1">以是个整数,一个数组,一个相关数组(associative array)或是个对象。 <br style="zoom:1"><br style="zoom:1">  方法在类中被定义成函数形式,在方法中访问类成员变量时,你应该使用$this->name,否则对一个方 <br style="zoom:1">法来说,他只能是局部变量。 <br style="zoom:1"><br style="zoom:1">  使用new操作符来创建一个对象: <br style="zoom:1"><br style="zoom:1">  $obj=new something; <br style="zoom:1"><br style="zoom:1">  然后你能使用成员函数通过: <br style="zoom:1"><br style="zoom:1">  $obj->setx(5); <br style="zoom:1">  $see=$obj->getx(); <br style="zoom:1"><br style="zoom:1">  在这个例子中,setx成员函数将5赋值给对象的成员变量x(不是类的),然后getx返回他的值5。 <br style="zoom:1"><br style="zoom:1">  你能象:$obj->x=6那样通过类引用方式来存取数据成员,这不是个非常好的oop习惯。我强烈建议通 <br style="zoom:1">过方法来存取成员变量。如果你把成员变量看成是不可处理的,并且只通过对象句柄来使用方法,你将是一 <br style="zoom:1">个好的oop程式员。不幸的是,php不支持声明私有成员变量,所以不良代码在php中也是允许的。 <br style="zoom:1"><br style="zoom:1">  继承在php中非常容易实现,只要使用extend关键字。 <br style="zoom:1"><br style="zoom:1"><br style="zoom:1"><br style="zoom:1">----------------------------------------------------- <br style="zoom:1"><?php <br style="zoom:1"><br style="zoom:1">class another extends something { <br style="zoom:1">var $y; <br style="zoom:1">function sety($v) { <br style="zoom:1">$this->y=$v; <br style="zoom:1">} <br style="zoom:1">function gety() { <br style="zoom:1">return $this->y; <br style="zoom:1">} <br style="zoom:1">} <br style="zoom:1"><br style="zoom:1">?>--------------------------------------------------- <br style="zoom:1"><br style="zoom:1">"another"类的对象目前拥有了父类(something)的全部的数据成员及方法,而且还加上了自已的数据成 员和方法。 <br style="zoom:1"><br style="zoom:1">你能使用 <br style="zoom:1">$obj2=new something; <br style="zoom:1">$obj2->setx(6); <br style="zoom:1">$obj2->sety(7); <br style="zoom:1"><br style="zoom:1">php目前还不支持多重继承,所以你不能从两个或两个以上类派生出新的类来。 <br style="zoom:1"><br style="zoom:1">你能在派生类中重定义一个方法,如果我们在"another"类中重定义了getx方法,我们就不能使 用"something"中的getx方法了。如果你在派生类中声明了一个和基派同名的数据成员,那么当你处理他时, 他将“隐藏”基类的数据成员。 <br style="zoom:1"><br style="zoom:1">你能在你的类中定义构造函数。构造函数是个和类名同名的方法,当你创建一个类的对象时会被调 用,例如: <br style="zoom:1">----------------------------------------------------- <br style="zoom:1"><?php <br style="zoom:1"><br style="zoom:1">class something { <br style="zoom:1">var $x; <br style="zoom:1"><br style="zoom:1">function something($y) { <br style="zoom:1">$this->x=$y; <br style="zoom:1">} <br style="zoom:1"><br style="zoom:1">function setx($v) { <br style="zoom:1">$this->x=$v; <br style="zoom:1">} <br style="zoom:1"><br style="zoom:1">function getx() { <br style="zoom:1">return $this->x; <br style="zoom:1">} <br style="zoom:1">} <br style="zoom:1"><br style="zoom:1">?>--------------------------------------------------- <br style="zoom:1"><br style="zoom:1">  所以你能创建一个对象,通过: <br style="zoom:1"><br style="zoom:1">  $obj=new something(6); <br style="zoom:1"><br style="zoom:1">  构造函数会自动地把6赋值给数据变量x。构造函数和方法都是普通的php函数,所以你能使用缺省参数。 <br style="zoom:1"><br style="zoom:1">  function something($x="3",$y="5") <br style="zoom:1">  接着: <br style="zoom:1">   $obj=new something(); // x=3 and y=5 <br style="zoom:1">  $obj=new something(8); // x=8 and y=5 <br style="zoom:1">  $obj=new something(8,9); // x=8 and y=9 <br style="zoom:1">  缺省参数使用c++的方式,所以你不能忽略y的值,而给x一个缺省参数,参数是从左到右赋值的,如果 <br style="zoom:1">传入的参数少于需求的参数时,其作的将使用缺省参数。 <br style="zoom:1"><br style="zoom:1">  当一个派生类的对象被创建时,只有他的构造函数被调用,父类的构造函数没被调用,如果你想调用基 <br style="zoom:1">类的构造函数,你必须要在派生类的构造函数中显示调用。能这样做是因为在派生类中所有父类的方法都 <br style="zoom:1">是可用的。 <br style="zoom:1">----------------------------------------------------- <br style="zoom:1"><?php <br style="zoom:1">function another() { <br style="zoom:1">$this->y=5; <br style="zoom:1">$this->something(); <br style="zoom:1">//显示调用基类构造函数 <br style="zoom:1">} <br style="zoom:1"><br style="zoom:1">?>--------------------------------------------------- <br style="zoom:1"><br style="zoom:1">  oop的一个非常好的机制是使用抽象类。抽象类是不能实例化,只能提供给派生类一个接口。设计者通常 <br style="zoom:1">使用抽象类来强迫程式员从基类派生,这样能确保新的类包含一些期待的功能。在php中没有标准的方法, <br style="zoom:1">不过: <br style="zoom:1"><br style="zoom:1">  如果你需要这个特性,能通过定义基类,并在他的构造函数后加上"die" 的调用,这样就能确保基 <br style="zoom:1">类是不可实例化的,目前在每一个方法(接口)后面加上"die" 语句,所以,如果一个程式员在派生类中没有 <br style="zoom:1">覆盖方法,将引发一个错误。而且因为php 是无类型的,你可能需要确认一个对象是来自于你的基类的派生 <br style="zoom:1">类,那么在基类中增加一个方法来实义类的身份(返回某种标识id),并且在你接收到一个对象参数时校验 <br style="zoom:1">这个值。当然,如果一个邪恶不好的程式员在派生类中覆盖了这个方法,这种方法就不起作用了,不过一般 <br style="zoom:1">问题多发目前懒惰的程式员身上,而不是邪恶的程式员。 <br style="zoom:1"><br style="zoom:1">  当然,能够让基类对程式员无法看到是非常好的,只要将接口打印出来做他们的工作就能了。 <br style="zoom:1"><br style="zoom:1">  在php中没有析构函数。 <br style="zoom:1"> 重载(和覆盖不同)在php中不支持。在oop中,你能重载一个方法来实现两个或重多的方法具有相同 <br style="zoom:1">的名字,不过有不同数量或类型的参数(这要看语言)。php 是一种松散类型的语言,所以通过类型重载不 <br style="zoom:1">起作用,然而通过参数的个数不同来重载也不起作用。 <br style="zoom:1"><br style="zoom:1">  有时在oop中重载构造函数非常好,这样你能通过不同的方法创建对象(传递不同数量的参数)。在php <br style="zoom:1">中实现他的技巧是: <br style="zoom:1"><br style="zoom:1">----------------------------------------------------- <br style="zoom:1"><?php <br style="zoom:1"><br style="zoom:1">class myclass { <br style="zoom:1">function myclass() { <br style="zoom:1">$name="myclass".func_num_args(); <br style="zoom:1">$this->$name(); <br style="zoom:1"><br style="zoom:1">//注意$this->name()一般是错误的,不过在这里$name是个将被调用方法的名字 <br style="zoom:1">} <br style="zoom:1">function myclass1($x) { <br style="zoom:1">code; <br style="zoom:1">} <br style="zoom:1">function myclass2($x,$y) { <br style="zoom:1">code; <br style="zoom:1">} <br style="zoom:1">} <br style="zoom:1"><br style="zoom:1">?>--------------------------------------------------- <br style="zoom:1">  通过在类中的额外的处理,使用这个类对用户是透明的: <br style="zoom:1">   $obj1=new myclass(1); //将调用myclass1 <br style="zoom:1">  $obj2=new myclass(1,2); //将调用myclass2 <br style="zoom:1"><br style="zoom:1">  有时这个非常好用。 <br style="zoom:1"><br style="zoom:1">待续...</p>



本文章来至源码世界 http://www.ymsky.net/views/123334.shtml


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。