The demo code is as follows: class ClassOne { 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();
?>
Output result:
In Class One
It can be seen that its method is implemented through the proxy class ClassOneDelegator instead of the ClassOne class.
Similarly, the following code can also be run:
function callClassOne() {
print "In Class One";
}
}
class ClassOneDelegator {
private $ targets;
function addObject($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();
?> ;