(PHP 5 >= 5.4.0, PHP 7)
Closure::bindTo — Дублирует замыкание с указанием связанного объекта и области видимости класса
Создает и возвращает новую анонимную функцию с тем же телом функции и связанными переменными, но с другим связанным объектом или новой областью видимости класса.
"Связанный объект" определяет значение $this,
которое будет доступно в теле функции, а "область видимости класса"
представляет собой класс, который определяет к каким protected (защищенным)
и private (закрытым) элементам этого объекта будет иметь доступ анонимная функция.
Если точнее, то это те элементы, как если бы анонимная функция была бы
методом класса, переданного в параметре newscope
.
Статические замыкания не могут иметь привязанный объект (значение параметра
newthis
должно быть равно NULL
), но эта функция может все равно
использоваться для изменения его области видимости класса.
Данный метод гарантирует, что у нестатического замыкания с привязанным
объектом будет задана область видимости и наоборот.
Для выполнения этого условия применяются следующие правила:
Для нестатического замыкания с указанной областью видимости и с NULL
вместо объекта, будет создано статическое замыкание.
Для нестатического замыкания с незаданной областью видимости, но с указанием
объекта, создается замыкание с неуказанной областью видимости.
Замечание:
Если вам необходимо только дублировать анонимную функцию, то вы можете вместо данного метода использовать клонирование.
newthis
Объект, к которому будет привязана переданная анонимная функция, или
NULL
для отсоединения замыкания от ее текущего объекта.
newscope
Область видимости класса, к которой привязывается замыкание, или 'static' для сохранения текущей области видимости. Если передан объект, то будет использован его класс. Этот параметр определяет видимость protected (защищенных) и private (закрытых) методов привязанного объекта. Запрещается передавать в этот параметр внутренний класс (объект класса).
Возвращает новый объект Closure
или FALSE
в случае возникновения ошибки
Версия | Описание |
---|---|
7.0.0 |
Параметр newscope больше не может быть задан
внутренним классом (объектом класса). Ранее это было возможно.
|
Пример #1 Пример Closure::bindTo()
<?php
class A {
function __construct($val) {
$this->val = $val;
}
function getClosure() {
//возвращает замыкание, связанное с текущими объектом и областью видимости
return function() { return $this->val; };
}
}
$ob1 = new A(1);
$ob2 = new A(2);
$cl = $ob1->getClosure();
echo $cl(), "\n";
$cl = $cl->bindTo($ob2);
echo $cl(), "\n";
?>
Результатом выполнения данного примера будет что-то подобное:
1 2