自 PHP 5.4 起可用 callable 类型指定回调类型 callback。本文档基于同样理由使用 callback 类型信息。
一些函数如 call_user_func() 或 usort() 可以接受用户自定义的回调函数作为参数。回调函数不止可以是简单函数,还可以是对象的方法,包括静态类方法。

传递

一个 PHP 的函数以 string 类型传递其名称。可以使用任何内置或用户自定义函数,但除了语言结构例如: array() , echo ,empty() , eval() , exit() , isset() , list() , print 或 unset() 。
一个已实例化的对象的方法被作为数组传递,下标 0 包含该对象,下标 1 包含方法名。
静态类方法也可不经实例化该类的对象而传递,只要在下标 0 中包含类名而不是对象。自 PHP 5.2.3 起,也可以传递 ‘ClassName::methodName’
除了普通的用户自定义函数外, create_function() 可以用来创建一个匿名回调函数。自 PHP 5.3.0 起也可传递 closure 给回调参数。

  1. <?php
  2. // An example callback function
  3. function my_callback_function () {
  4. echo 'hello world!' ;
  5. }
  6. // An example callback method
  7. class MyClass {
  8. static function myCallbackMethod () {
  9. echo 'Hello World!' ;
  10. }
  11. }
  12. // Type 1: Simple callback
  13. call_user_func ( 'my_callback_function' );
  14. // Type 2: Static class method call
  15. call_user_func (array( 'MyClass' , 'myCallbackMethod' ));
  16. // Type 3: Object method call
  17. $obj = new MyClass ();
  18. call_user_func (array( $obj , 'myCallbackMethod' ));
  19. // Type 4: Static class method call (As of PHP 5.2.3)
  20. call_user_func ( 'MyClass::myCallbackMethod' );
  21. // Type 5: Relative static class method call (As of PHP 5.3.0)
  22. class A {
  23. public static function who () {
  24. echo "A\n" ;
  25. }
  26. }
  27. class B extends A {
  28. public static function who () {
  29. echo "B\n" ;
  30. }
  31. }
  32. call_user_func (array( 'B' , 'parent::who' )); // A
  33. ?>

例2

  1. <?php
  2. // Our closure
  3. $double = function( $a ) {
  4. return $a * 2 ;
  5. };
  6. // This is our range of numbers
  7. $numbers = range ( 1 , 5 );
  8. // Use the closure as a callback here to
  9. // double the size of each element in our
  10. // range
  11. $new_numbers = array_map ( $double , $numbers );
  12. print implode ( ' ' , $new_numbers );
  13. ?>

以上例程会输出:
2 4 6 8 10

Note: 在 PHP 4 中,需要使用一个引用来创建一个指向具体对象的回调函数,而不是一个拷贝。参见引用的解释。

Note:
在函数中注册有多个回调内容时(如使用 call_user_func() 与 call_user_func_array() ),如在前一个回调中有未捕获的异常,其后的将不再被调用