Heim >Backend-Entwicklung >PHP-Tutorial >PHP 5.0构造函数的实例讲解_PHP教程

PHP 5.0构造函数的实例讲解_PHP教程

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-07-15 13:28:39879Durchsuche

大家都对如果你在一个类中声明一个函数,命名为__construct,这个函数将被当成是一个构造函数并在建立一个对象实例时被执行。清楚地说,__是两个下划线。就像其它任何函数一样,PHP 5.0构造函数可能有参数或者默认值. 你可以定义一个类来建立一个对象并将其属性全放在一个语句(statement)中。

你也可以定义一个名为__destruct的函数,PHP将在对象被销毁前调用这个函数. 它称为析构函数.

继承是类的一个强大功能。一个类(子类/派生类)可以继承另一类(父类/基类)的功能. 派生类将包含有基类的所有属性和方法,并可以在派生类中加上其他属性和方法。你也可以覆写基类的方法和属性。就像前文中显示的,你可以用extends关键字来继承一个类。

你可能想知道PHP 5.0构造函数是如何被继承的。当它们和其它方法一起被继承时,他们不会在创建对象时被执行。

如果你需要这个功能,你需要用到::运算符. 它允许你指向一块命名空间. parent指向父类命名空间,你可以用parent::__construct来调用父类的构造函数。

一些面向对象语言在类之后命名构造函数。PHP的前几个版本也是如此,到现在这种方法仍然有效.也就是:如果你把一个类命名为Animal并且在其中建立一个命名也是Animal的方法,则这个方法就是构造函数.如果一个类的同时拥有__construt构造函数和与类名相同的函数,PHP将把__construct看作构造函数。这使得用以前的PHP版本所写的类仍然可以使用. 但新的脚本(PHP5)应当使用__construct。

PHP的这种新的声明构造函数的方法可以使PHP 5.0构造函数有一个独一无二的名称,无论它所在的类的名称是什么。这样你在改变类的名称时,就不需要改变构造函数的名称。

你可能在PHP中给构造函数一个像其它类方法一样的访问方式。访问方式将会影响从一定范围内实例化对象的能力。这允许实现一些固定的设计模式,如Singleton模式。

析构函数,相反于构造函数。PHP调用它们来将一个对象从内存中销毁。默认地,PHP仅仅释放对象属性所占用的内存并销毁对象相关的资源。析构函数允许你在使用一个对象之后执行任意代码来清除内存。

当PHP决定你的脚本不再与对象相关时,析构函数将被调用. 在一个函数的命名空间内,这会发生在函数return的时候. 对于全局变量,这发生于脚本结束的时候. 如果你想明确地销毁一个对象,你可以给指向该对象的变量分配任何其它值. 通常将变量赋值勤为NULL或者调用unset。

下面的例子中,计算从类中实例化的对象的个数. Counter类从PHP 5.0构造函数开始增值,在析构函数减值。

<ol class="dp-xml">
<li class="alt"><span><span>class Counter   </span></span></li>
<li class=""><span>{   </span></li>
<li class="alt">
<span> private static $</span><span class="attribute"><font color="#ff0000">count</font></span><span> = </span><span class="attribute-value"><font color="#0000ff">0</font></span><span>;   </span>
</li>
<li class=""><span> </span></li>
<li class="alt"><span> function __construct()   </span></li>
<li class=""><span> {   </span></li>
<li class="alt"><span>self::$count++;   </span></li>
<li class=""><span> }   </span></li>
<li class="alt"><span> </span></li>
<li class=""><span> function __destruct()   </span></li>
<li class="alt"><span> {   </span></li>
<li class=""><span>self::$count--;   </span></li>
<li class="alt"><span> }   </span></li>
<li class=""><span> </span></li>
<li class="alt"><span> function getCount()   </span></li>
<li class=""><span> {   </span></li>
<li class="alt"><span>return self::$count;   </span></li>
<li class=""><span> }   </span></li>
<li class="alt"><span>}   </span></li>
<li class=""><span> </span></li>
<li class="alt"><span>//建立第一个实例   </span></li>
<li class="">
<span>$</span><span class="attribute"><font color="#ff0000">c</font></span><span> = </span><span class="attribute-value"><font color="#0000ff">new</font></span><span> Counter();   </span>
</li>
<li class="alt"><span> </span></li>
<li class=""><span>//输出1   </span></li>
<li class="alt"><span>print($c->getCount() . "n");   </span></li>
<li class=""><span> </span></li>
<li class="alt"><span>//建立第二个实例   </span></li>
<li class="">
<span>$</span><span class="attribute"><font color="#ff0000">c2</font></span><span> = </span><span class="attribute-value"><font color="#0000ff">new</font></span><span> Counter();   </span>
</li>
<li class="alt"><span> </span></li>
<li class=""><span>//输出2   </span></li>
<li class="alt"><span>print($c->getCount() . "n");   </span></li>
<li class=""><span> </span></li>
<li class="alt"><span>//销毁实例   </span></li>
<li class="">
<span>$</span><span class="attribute"><font color="#ff0000">c2</font></span><span> = </span><span class="attribute-value"><font color="#0000ff">NULL</font></span><span>;   </span>
</li>
<li class="alt"><span> </span></li>
<li class=""><span>//输出1   </span></li>
<li class="alt"><span>print($c->getCount() . "n");   </span></li>
<li class=""><span>?>  </span></li>
</ol>

一旦你定义了一个类,你可以用new来建立一个这个类的实例. 类的定义是设计图,实例则是放在装配线上的元件. New需要类的名称,并返回该类的一个实例。如果PHP 5.0构造函数需要参数,你应当在new后输入参数。


www.bkjia.comtruehttp://www.bkjia.com/PHPjc/446433.htmlTechArticle大家都对 如果你在一个类中声明一个函数,命名为__construct,这个函数将被当成是一个构造函数并在建立一个对象实例时被执行。清楚地说...
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn