04-看官方文档学PHP面向对象-构造函数和析构函数

构造函数

void __construct ([ mixed $args [, $... ]] )

具有构造函数的类会在每次创建新对象时先调用此方法,所以构造函数非常适合在使用对象之前做一些初始化工作。

  1. 如果子类中定义了构造函数则不会隐式调用其父类的构造函数。
  2. 要执行父类的构造函数,需要在子类的构造函数中调用 parent::__construct()
  3. 如果子类没有定义构造函数则会如同一个普通的类方法一样从父类继承(假如没有被定义为 private 的话)
  4. 与其它方法不同,当 __construct() 被与父类 __construct() 具有不同参数的方法覆盖时,PHP 不会产生一个 E_STRICT 错误信息。
  5. 自 PHP 5.3.3 起,在命名空间中,与类名同名的方法不再作为构造函数。 这一改变不影响不在命名空间中的类。

Example #1 使用新标准的构造函数

<?php
class BaseClass {
function __construct() {
print "In BaseClass constructor\n";
}
}

class SubClass extends BaseClass {
function __construct() {
parent::__construct();
print "In SubClass constructor\n";
}
}

class OtherSubClass extends BaseClass {
// inherits BaseClass's constructor
}

// In BaseClass constructor
$obj = new BaseClass();

// In BaseClass constructor
// In SubClass constructor
$obj = new SubClass();

// In BaseClass constructor
$obj = new OtherSubClass();
?>

the easiest way to use and understand multiple constructors:

<?php
class A
{
function __construct()
{
$a = func_get_args(); // 返回一个包含函数参数列表的数组
$i = func_num_args(); // Returns the number of arguments passed to the function

if (method_exists($this, $f = '__construct' . $i)) {
// 把第一个参数作为回调函数(callback)调用,把第二个参数数组作(param_arr)为回调函数的的参数传入。
call_user_func_array(array($this, $f), $a);
}
}

function __construct1($a1)
{
echo('__construct with 1 param called: '.$a1.PHP_EOL);
}

function __construct2($a1,$a2)
{
echo('__construct with 2 params called: '.$a1.','.$a2.PHP_EOL);
}

function __construct3($a1,$a2,$a3)
{
echo('__construct with 3 params called: '.$a1.','.$a2.','.$a3.PHP_EOL);
}
}
$o = new A('sheep');
$o = new A('sheep','cat');
$o = new A('sheep','cat','dog');

// results:
// __construct with 1 param called: sheep
// __construct with 2 params called: sheep,cat
// __construct with 3 params called: sheep,cat,dog
}
?>

析构函数

void __destruct ( void )
  1. 析构函数会在到某个对象的所有引用都被删除或者当对象被显式销毁时执行。
  2. 父类的析构函数不会被引擎暗中调用。
  3. 要执行父类的析构函数,必须在子类的析构函数体中显式调用 parent::__destruct()
  4. 子类如果自己没有定义析构函数则会继承父类的。
  5. 析构函数即使在使用 exit() 终止脚本运行时也会被调用。
  6. 在析构函数中调用 exit() 将会中止其余关闭操作的运行。
  7. 析构函数在脚本关闭时调用,此时所有的 HTTP 头信息已经发出。
  8. 脚本关闭时的工作目录有可能和在 SAPI(如 apache)中时不同。
  9. 在析构函数中抛出异常会导致致命错误发生。

Example #3 析构函数示例

<?php
class MyDestructableClass {
function __construct() {
print "In constructor\n";
$this->name = "MyDestructableClass";
}

function __destruct() {
print "Destroying " . $this->name . "\n";
}
}

$obj = new MyDestructableClass();
?>
0%