Демо-код выглядит следующим образом:
<?php
класс ClassOne {
функция callClassOne() {
напечатайте «В первом классе»;
}
}
класс ClassOneDelegator {
частные $цели;
функция __construct() {
$this->target[] = новый ClassOne();
}
функция __call($name, $args) {
foreach ($this->target as $obj) {
$r = новый ReflectionClass($obj);
if ($method = $r->getMethod($name)) {
if ($method->isPublic() && !$method->isAbstract()) {
вернуть $method->invoke($obj, $args);
}
}
}
}
}
$obj = новый ClassOneDelegator();
$obj->callClassOne();
?>
Результат вывода:
В первом классе
Видно, что его метод реализован через прокси-класс ClassOneDelegator вместо класса ClassOne.
Аналогично можно запустить следующий код:
<?php
класс ClassOne {
функция callClassOne() {
напечатайте «В первом классе»;
}
}
класс ClassOneDelegator {
частные $цели;
функция addObject($obj) {
$this->target[] = $obj;
}
функция __call($name, $args) {
foreach ($this->target as $obj) {
$r = новый ReflectionClass($obj);
if ($method = $r->getMethod($name)) {
if ($method->isPublic() && !$method->isAbstract()) {
вернуть $method->invoke($obj, $args);
}
}
}
}
}
$obj = новый ClassOneDelegator();
$obj->addObject(новый ClassOne());
$obj->callClassOne();
?>