__construct(),类的构造函数,使用new对象是自动调用
例如:下面声明一个demo类
<?php
class demo{
function __construct() {
echo "demo类被实例化了";
}
}
$demo=new demo();
运行这段代码,会输出:
demo类被实例化了
一般用来当类的某些属性在构造时就需要被赋值时使用
如
class person{
private $name;
private $age
function __construct($name,$age){
$this->name=$name;
$this->age=$age;
}
}
$person1=new person('zh','8');
此时person在初始化时就name和age属性(字段?)就已经有初始值,就不用再自己设置了,
此处我将属性声明为私有的,可以通过__set() __get()魔术方法实现对其读取和赋值
注意:
如果子类中定义了构造函数则不会隐式调用其父类的构造函数。要执行父类的构造函数,需要在子类的构造函数中调用
如果子类没有定义构造函数则会如同一个普通的类方法一样从父类继承(假如没有被定义为 private 的话)
兼容性问题:
为了实现向后兼容性,如果 PHP 5 在类中找不到 __construct() 函数并且也没有从父类继承一个的话,它就会尝试寻找旧式的构造函数,也就是和类同名的函数。因此唯一会产生兼容性问题的情况是:类中已有一个名为 __construct() 的方法却被用于其它用途时。
与其它方法不同,当 __construct() 被与父类 __construct() 具有不同参数的方法覆盖时,PHP 不会产生一个 E_STRICT
错误信息。
自 PHP 5.3.3 起,在命名空间中,与类名同名的方法不再作为构造函数。这一改变不影响不在命名空间中的类。
__destruct(),类的析构函数 , 在到某个对象的所有引用都被删除或者当对象被显式销毁时执行。
实例:
<?php
class demo{
function __construct() {
echo "demo类被实例化了";
}
function __destruct(){
echo '<br/>demo类被销毁了';
}
}
$demo=new demo();
unset($demo); 常用与关闭资源类型的东西,如文件操作,等
注意:
和构造函数一样,父类的析构函数不会被引擎暗中调用。要执行父类的析构函数,必须在子类的析构函数体中显式调用 parent::__destruct()。此外也和构造函数一样,子类如果自己没有定义析构函数则会继承父类的。
析构函数即使在使用 exit() 终止脚本运行时也会被调用。在析构函数中调用 exit() 将会中止其余关闭操作的运行。
析构函数在脚本关闭时调用,此时所有的 HTTP 头信息已经发出。脚本关闭时的工作目录有可能和在 SAPI(如 apache)中时不同。
试图在析构函数(在脚本终止时被调用)中抛出一个异常会导致致命错误。