Über die Proxy-Klasse ClassOneDelegator anstelle der ClassOne-Klasse, um ihre Methoden zu implementieren.
Der Demonstrationscode lautet wie folgt:
<?php class ClassOne { function callClassOne() { print "In Class One"; } } class ClassOneDelegator { private $targets; function construct() { $this->target[] = new ClassOne(); } function call($name, $args) { foreach ($this->target as $obj) { $r = new ReflectionClass($obj); if ($method = $r->getMethod($name)) { if ($method->isPublic() && !$method->isAbstract()) { return $method->invoke($obj, $args); } } } } } $obj = new ClassOneDelegator(); $obj->callClassOne(); ?>
Ausgabeergebnis:
In Klasse Eins
Es ist ersichtlich, dass die Proxy-Klasse ClassOneDelegator anstelle der ClassOne-Klasse verwendet wird seine Methode umzusetzen.
Ähnlich kann auch der folgende Code ausgeführt werden:
<?php class ClassOne { function callClassOne() { print "In Class One"; } } class ClassOneDelegator { private $targets; function add Object ($obj) { $this->target[] = $obj; } function call($name, $args) { foreach ($this->target as $obj) { $r = new ReflectionClass($obj); if ($method = $r->getMethod($name)) { if ($method->isPublic() && !$method->isAbstract()) { return $method->invoke($obj, $args); } } } } } $obj = new ClassOneDelegator(); $obj->addObject(new ClassOne()); $obj->callClassOne(); ?>
Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Implementierung des Codes für den PHP-Reflektionsmechanismus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!