Callbacks / Callables

Callbacks können seit PHP 5.4 mit dem Type-Hint callable gekennzeichnet werden. Diese Dokumentation verwendete auch die Typinformation callback für diesen Zweck.

Einige Funktionen wie call_user_func() oder usort() akzeptieren eine benutzerdefinierte Callback-Funktion als Argument. Callback-Funktionen können nicht nur einfache Funktionen sein, sondern auch Methoden eines Objects, inklusive statischer Klassenmethoden.

Übergabe

Eine PHP-Funktion wird anhand ihres Namens als String übergeben. Jede eingebaute oder benutzerdefinierte Funktion kann verwendet werden, außer Sprachkonstrukten wie: array(), echo, empty(), eval(), exit(), isset(), list(), print oder unset().

Eine Methode eines instantiierten Objects wird übergeben als Array mit dem Object an Index-Position 0 und dem Methodennamen an Position 1. Der Zugriff auf als protected oder private markierte Methoden von innerhalb der Klasse ist erlaubt.

Statische Klassenmethoden können auch übergeben werden, ohne dann ein Object dieser Klasse instantiiert werden muss, indem man den Namen der Klasse statt eines Objects an Index 0 übergibt. Seit PHP 5.2.3 kann man auch 'ClassName::methodName' übergeben.

Neben den üblichen benutzerdefiniersten Funktionen können auch anonyme Funktionen als Callback-Agumente übergeben werden.

Beispiel #1 Beispiele für Callback-Funktionen

<?php

// Eine Beispiel-Callback-Funktion
function my_callback_function() {
    echo 
'hello world!';
}

// Eine Beispiel-Callback-Methode
class MyClass {
    static function 
myCallbackMethod() {
        echo 
'Hello World!';
    }
}

// Typ 1: Einfaches Callback
call_user_func('my_callback_function');

// Typ 2: Statischer Methodenaufruf
call_user_func(array('MyClass''myCallbackMethod'));

// Typ 3: Aufruf einer Objektmethode
$obj = new MyClass();
call_user_func(array($obj'myCallbackMethod'));

// Typ 4: Statischer Methodenaufruf (Seit PHP 5.2.3)
call_user_func('MyClass::myCallbackMethod');

// Typ 5: Relativer statischer Methodenaufruf (Seit PHP 5.3.0)
class {
    public static function 
who() {
        echo 
"A\n";
    }
}

class 
extends {
    public static function 
who() {
        echo 
"B\n";
    }
}

call_user_func(array('B''parent::who')); // A

// Typ 6: Objekte die __invoke implementieren können als Callable verwendet werden (seit PHP 5.3)
class {
    public function 
__invoke($name) {
        echo 
'Hello '$name"\n";
    }
}

$c = new C();
call_user_func($c'PHP!');
?>

Beispiel #2 Fallback-Beispiel mit einem Closure

<?php
// Unser Closure
$double = function($a) {
    return 
$a 2;
};

// Dies ist unsere Menge an Zahlen
$numbers range(15);

// Hier verwenden wir das Callback, um
// den Wert jedes Elements in unserer
// Menge zu verdoppeln
$new_numbers array_map($double$numbers);

print 
implode(' '$new_numbers);
?>

Das oben gezeigte Beispiel erzeugt folgende Ausgabe:

2 4 6 8 10

Hinweis:

Callbacks, die für Funktionen wie call_user_func() und call_user_func_array() registriert sind, werden nicht mehr ausgeführt, wenn in einem vorherigen Callback eine Exception geworfen und nicht gefangen wurde.