Rumah >pembangunan bahagian belakang >tutorial php >PHP学习(二):PHP的魔术方法
PHP把所有以__(两个下划线)开头的类方法当成魔术方法。所以你定义自己的类方法时,不要以 __为前缀。
1、__construct()
当实例化一个对象的时候,这个对象的构造方法将首先被调用;
我们知道php5对象模型和类名相同的函数是类的构造函数,那么如果同时定义构造函数和__construc()方法的话,php5会默认调用__contruct()而不会调用同类名函数,所以__contruct()作为类的默认构造函数;
header('content-type:text/html;charset=utf-8'); class person{ private $name; /** * 构造函数-当你调用 new person创建对象的时候就调用. * @param string */ function __construct($name='啦'){ echo '调用构造'.$name; }}$obj = new person();//就会输出 "调用构造啦"五个字
2、__destruct()
析构函数会在到某个对象的所有引用都被删除或者当对象被显式销毁时执行。
header('content-type:text/html;charset=utf-8'); class person{ private $_name; function __construct($val){ $this->_name = $val; } function __destruct(){ echo $this->_name.'调用析构函数<br/>'; } }$obj1 = new person('1');$obj2 = new person('2');$obj3 = new person('3');//因为以堆载的形式存入内存,析构时以的原则是后进先出,所以obj3先被析构,输出以下//3调用析构函数//2调用析构函数//1调用析构函数
header('content-type:text/html;charset=utf-8'); class person{ private $_name; function __construct($val){ $this->_name = $val; } function __destruct(){ echo $this->_name.'调用析构函数<br/>'; } }$obj1 = new person('1');$obj2 = new person('2');unset($obj2);$obj3 = new person('3');//值得注意的是,您如果再中间用unset移除了obj2或者用obj2=null显示移除 输出以下//会先执行析构obj2然后再执行obj3//2调用析构函数//3调用析构函数//1调用析构函数
3、__get(string $name)
当试图读取一个并不存在的属性时被调用;如果试图读取一个对象并不存在的属性的时候,php就会给出错误的信息。如果在类里添加__get方法,并且我们可以用这个函数实现类似java中的反射的各种操作。
header('content-type:text/html;charset=utf-8'); class person{ private $name; function __get($val){ return '没有这个名称的属性'.$val; }}$obj = new person();echo $obj->name;//调用没有的属性输出该属性的值时,就能调用__get()魔术函数 $val就是你调用属性名称 //值得注意的是,没存在和定义私有修饰符,都属于未定义, 子类继承父类获取不到也一样//输出:没有这个名称的属性name
4、__set(string $name, mixed $value)
给未定义的变量赋值时将被调用
header('content-type:text/html;charset=utf-8'); class person{ private $name; /** * 给未定的属性赋值 参数1=属性名,参数2=值(任意类型) * @param string $key * @param mixed $val */ function __set($key,$val){ return '给没定义属性'.$key.'赋值'.$val; }}$obj = new person();echo $obj->age = '大只猪';//输出:大只猪
5、__call(string $name, array $arguments)
当调用一个不可访问方法(如未定义,或者不可见)时,__call() 会被调用。
__callStatic(string $name, array $arguments)
当在静态方法中调用一个不可访问方法(如未定义,或者不可见)时,__callStatic() 会被调用。
6、__toString()
当打印一个对象的时候被调用,这个方法类似于java的toString方法,当我们直接打印对象的时候回调这个函数。
7、__clone()
当对象被克隆时调用。
8、__sleep()
serialize()函数会检查是否存在一个魔术方法 __sleep.如果存在,__sleep()方法会先被调用, 然后才执行序列化操作。这个功能可以用于清理对象,并返回一个包含对象中所有变量名称的数组。如果该方法不返回任何内容,则NULL被序列化,导致 一个E_NOTICE错误。__sleep方法常用于提交未提交的数据,或类似的操作。同时,如果你有一些很大的对象,不需要保存,这个功能就很好用。
9、__wakeup()
与__sleep() 相反,unserialize()会检查是否存在一个__wakeup方法。如果存在,则会先调用 __wakeup方法,预先准备对象数据。__wakeup经常用在反序列化操作中,例如重新建立数据库连接,或执行其它初始化操作。
10、__isset()
当对未定义的变量调用isset() 或 empty()时,__isset() 会被调用。
11、__unset()
unset一个对象的属性时被调用。如:unset($c->name)。
12、__set_state()
调用var_export时,被调用。用__set_state的返回值做为var_export的返回值。
13、__autoload()
实例化一个对象时,如果对应的类不存在,则该方法被调用。简单的说就是类的自动加载;当你尝试使用一个PHP没有组织到的类, 它会寻找一个__autoload的全局函数. 如果存在这个函数,PHP会用一个参数来调用它,参数即类的名称。
14、__invoke()
当尝试以调用函数的方式调用一个对象时,__invoke 方法会被自动调用。
魔术常量:
__LINE__ 文件中的当前行号。
__FILE__ 文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。自 PHP 4.0.2 起,__FILE__ 总是包含一个绝对路径(如果是符号连接,则是解析后的绝对路径),而在此之前的版本有时会包含一个相对路径。
__DIR__ 文件所在的目录。如果用在被包括文件中,则返回被包括的文件所在的目录。它等价于 dirname(__FILE__)。除非是根目录,否则目录中名不包括末尾的斜杠。(PHP 5.3.0中新增) =
__FUNCTION__ 函数名称(PHP 4.3.0 新加)。自 PHP 5 起本常量返回该函数被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。
__CLASS__ 类的名称(PHP 4.3.0 新加)。自 PHP 5 起本常量返回该类被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。
__METHOD__ 类的方法名(PHP 5.0.0 新加)。返回该方法被定义时的名字(区分大小写)。
__NAMESPACE__ 当前命名空间的名称(大小写敏感)。这个常量是在编译时定义的(PHP 5.3.0 新增)