PHP魔术方法和魔术常量

1》魔术常量

1。__LINE__

返回文件中的当前行号。

2。__FILE__

  返回文件的完整路径和文件名。如果用在包含文件中,则返回包含文件名。自PHP4.0.2 起,__FILE__总是包含一个绝对路径,而在此之前的版本有时会包含一个相对路径。

3。__FUNCTION__

  返回函数名称(PHP4.3.0 新加)。自PHP5 起本常量返回该函数被定义时的名字(区分大小写)。在PHP4 中该值总是小写字母的。

4。__CLASS__

  返回类的名称(PHP4.3.0 新加)。自PHP5 起本常量返回该类被定义时的名字(区分大小写)。在PHP4 中该值总是小写字母的。

5。__METHOD__

  返回类的方法名(PHP5.0.0 新加)。返回该方法被定义时的名字(区分大小写)。

2》Class魔术方法

  魔术方法是PHP面向对象中很有用特性。它们在特定的情况下被触发,都是以双下划线开头,可以理解为钩子函数,利用模式方法可以轻松实现PHP面向对象中重载(Overloading即动态创建类属性和方法)。魔术方法很多还是成对出现的,以下列出目前PHP中所有的模式方法。

1.__construct,__destruct

__constuct构建对象的时被调用;

__destruct明确销毁对象或脚本结束时被调用;

2.__get,__set

__set当给不可访问或不存在属性赋值时被调用

__get读取不可访问或不存在属性时被调用

3.__isset,__unset

__isset对不可访问或不存在的属性调用isset()或empty()时被调用

__unset对不可访问或不存在的属性进行unset时被调用

4.__call,__callStatic

__call调用不可访问或不存在的方法时被调用

__callStatic调用不可访问或不存在的静态方法时被调用

5.__sleep,__wakeup

__sleep当使用serialize时被调用,当你不需要保存大对象的所有数据时很有用

__wakeup当使用unserialize时被调用,可用于做些对象的初始化操作

6.__clone

进行对象clone时被调用,用来调整对象的克隆行为

7.__toString

当一个类被转换成字符串时被调用

8.__invoke

当以函数方式调用对象时被调用

9.__set_state

当调用var_export()导出类时,此静态方法被调用。用__set_state的返回值做为var_export的返回值。

10.__debuginfo

当调用var_dump()打印对象时被调用(当你不想打印所有属性)适用于PHP5.6版本

类定义
class Animal{
}
$m = new Animal(); //__construct()被调用
$m->not_exist_property = test; //__set()被调用
echo $m->not_exist_property;//__get()被调用
$m->abc(1,2,3); //__call()被调用
echo isset($m->not_exist_property); //__isset()被调用,返回bool值
unset($m->not_exist_property); //__unset()被调用
echo $tmp = serialize($m); //__sleep()被调用
unserialize($tmp); //__wakeup()被调用
$m1 = clone $m; //__clone()被调用,对象默认是引用传递,使用clone关键词则可实现对象复制
$m(); //__invoke() 已函数调用类
eval( '$m2 = ' . var_export ( $m , true ) . ';' );
var_dump($m2);
var_dump($m);
//最后__destruct()被调用

3>反射函数

3.1>常用

bool class_exists ( string $class_name [, bool $autoload = true ] ) 检查指定的类是否已定义。

bool method_exists ( mixed$object , string $method_name ) 检查类的方法是否存在于指定的 object中。

bool function_exists ( string $function_name ) 在已经定义的函数列表(包括系统自带的函数和用户自定义的函数)中查找 function_name

bool property_exists ( mixed$class , string $property ) 本函数检查给出的 property 是否存在于指定的类中(以及是否能在当前范围内访问)。

bool is_callable ( callable$name [, bool $syntax_only = false [, string &$callable_name ]] ) 验证变量的内容能否作为函数调用。 这可以检查包含有效函数名的变量,或者一个数组,包含了正确编码的对象以及函数名。

3.2>调用

mixedcall_user_func ( callable$callback [, mixed$parameter [, mixed$... ]] ) 单入参

mixedcall_user_func_array ( callable$callback , array $param_arr ) 多入参

3.3> 接口

bool interface_exists ( string $interface_name [, bool $autoload = true ] )

array get_declared_interfaces ( void )

array class_implements ( mixed$class [, bool $autoload ] ) 本函数返回一个数组,该数组中包含了指定类class及其父类所实现的所有接口的名称。

3.4》扩展模块

bool extension_loaded ( string $name ) 检查一个扩展是否已经加载。

array get_loaded_extensions ([ bool $zend_extensions = false ] ) 该函数返回了 PHP 解析器里所有编译并加载的模块名。

array get_extension_funcs ( string $module_name ) 返回包含所有函数名的数组,如果 module_name 不是一个有效的扩展则返回 FALSE