Closure::bindTo

(PHP 5 >= 5.4.0, PHP 7, PHP 8)

Closure::bindTo 復制當前閉包對象,綁定指定的$this對象和類作用域。

說明

public Closure::bindTo(?object $newThis, object|string|null $newScope = "static"): ?Closure

創(chuàng)建并返回一個 匿名函數(shù), 它與當前對象的函數(shù)體相同、綁定了同樣變量,但可以綁定不同的對象,也可以綁定新的類作用域。

“綁定的對象”決定了函數(shù)體中的 $this 的取值,“類作用域”代表一個類型、決定在這個匿名函數(shù)中能夠調(diào)用哪些 private 和 protected 的方法。 也就是說,此時 $this 可以調(diào)用的方法,與 newScope 類的成員函數(shù)是相同的。

靜態(tài)閉包不能有綁定的對象( newThis 參數(shù)的值應該設(shè)為 null)不過仍然可以用 bindTo 方法來改變它們的類作用域。

此函數(shù)確保對于非靜態(tài)閉包,擁有綁定實例也意味著被限定作用域,反之亦然。 為此,非靜態(tài)閉包給定一個 null 實例的作用域可以使其變?yōu)殪o態(tài), 非靜態(tài)無作用域的閉包給定一個非 null 的實例作用在一個非指定類。

注意:

如果你只是想要復制一個匿名函數(shù),可以用 cloning 代替。

參數(shù)

newThis

綁定給匿名函數(shù)的一個對象,或者 null 來取消綁定。

newScope

關(guān)聯(lián)到匿名函數(shù)的類作用域,或者 'static' 保持當前狀態(tài)。如果是一個對象,則使用這個對象的類型為新的類作用域。 這會決定綁定的對象的 保護、私有成員 方法的可見性。 不允許內(nèi)部類(的對象)作為參數(shù)傳遞。

返回值

返回新創(chuàng)建的 Closure 對象, 或者失敗時返回 null 。

范例

示例 #1 Closure::bindTo() 實例

<?php

class {
    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

參見