Home  >  Article  >  Backend Development  >  特制大型PHP项目的方法

特制大型PHP项目的方法

WBOY
WBOYOriginal
2016-06-13 11:54:58860browse

研发大型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


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