public string __toString ( void )
__toString() 方法用于一个类被当成字符串时应怎样回应。例如 echo $obj; 应该显示些什么。此方法必须返回一个字符串,否则将发出一条E_RECOVERABLE_ERROR
级别的致命错误。
示例:
<?php // Declare a simple class class TestClass { public $foo; public function __construct($foo) { $this->foo = $foo; } public function __toString() { return $this->foo; } } $class = new TestClass('Hello'); echo $class; ?>
结果:
Hello
需要指出的是在 PHP 5.2.0 之前,__toString() 方法只有在直接使用于 echo 或 print 时才能生效。PHP 5.2.0 之后,则可以在任何字符串环境生效(例如通过 printf(),使用 %s 修饰符),但不能用于非字符串环境(如使用 %d 修饰符)。自 PHP 5.2.0 起,如果将一个未定义 __toString() 方法的对象转换为字符串,会产生 E_RECOVERABLE_ERROR
级别的错误。
mixed __invoke ([ $...
] )
当尝试以调用函数的方式调用一个对象时,__invoke() 方法会被自动调用。
Note:
本特性只在 PHP 5.3.0 及以上版本有效。
示例:
class CallableClass { function __invoke($x) { var_dump($x); } } $obj = new CallableClass; $obj(5); var_dump(is_callable($obj));
结果:
int(5) bool(true)
__invoke()定义参数可以为多个,引用时参数只能多不能少
示例:
<?php class CallableClass { function __invoke($x,$y) { var_dump($x); var_dump($y); } } $obj = new CallableClass; $obj(5); var_dump(is_callable($obj)); ?>
结果:
Warning: Missing argument 2 for CallableClass::__invoke(), called in D:\code\test\info.php on line 10 and defined inD:\code\test\info.php on line 4
int(5)
Notice: Undefined variable: y in D:\code\test\info.php on line 6
NULL bool(true)
示例:
class CallableClass { function __invoke($x,$y) { var_dump($x); var_dump($y); } } $obj = new CallableClass; $obj(5,4,5,6,7,2,'a'); var_dump(is_callable($obj));
结果:
int(5) int(4) bool(true)
static object __set_state ( array $properties
)
自 PHP 5.1.0 起当调用 var_export() 导出类时,此静态 方法会被调用。
本方法的唯一参数是一个数组,其中包含按 array('property' => value, ...) 格式排列的类属性。
Example #4 使用 __set_state()>(PHP 5.1.0 起)
示例:
class A { public $var1; public $var2; public static function __set_state($an_array) // As of PHP 5.1.0 { $obj = new A; $obj->var1 = $an_array['var1']; $obj->var2 = $an_array['var2']; return $obj; } } $a = new A; $a->var1 = 5; $a->var2 = 'foo'; eval('$b = ' . var_export($a, true) . ';');//调用__set_state $b成为一个新的A的对象; var_dump($b);
结果:
object(A)#2 (2) { ["var1"]=> int(5) ["var2"]=> string(3) "foo" }