PHP魔术方法和魔术常量
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>调用
mixed call_user_func ( callable $callback
[, mixed $parameter
[, mixed $...
]] ) 单入参
mixed call_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
。