天天看點

php 動态指派,PHP動态綁定

PHP動态綁定則針對運作期産生的通路請求,隻用到運作期的可用資訊。在面向對象的代碼中,動态綁定意味着決定哪個方法被調用或哪個屬性被通路,将基于這個類本身而不基于通路範圍。Public和protected成員的動作類似于PHP的前幾個版本中函數的動作,使用動态綁定。這意味着如果一個方法通路一個在子類中被覆寫的類成員,并是一個子類的執行個體,子類的成員将被通路(而不是通路父類中的成員)。

看 下面的例子,這段代碼輸出“ Hey! I am Son.” 因為當PHP調用getSalutation, 是一個Son的執行個體,是将Father中的salutation覆寫而來. 如果salutation是public的,PHP将産生相同的結果. 覆寫方法的操作很類似。在Son中,對于identify的調用綁定到那個方法。

即使在子類中通路方式被從protected削弱成public,動态綁定仍然會發生。 按照通路方式使用的原則,增強對于類成員的通路限制是不可能的,是以把通路方式從public改變成protected不可能進行。

Dynamic binding 動态綁定

salutationn");

$this->identify();

}

protected function identify()

{

print("I am Father.");

}

};

class Son extends Father

{

protected $salutation = "Hey!"; //父類中的protected $salutation 被覆寫

protected function identify() //父類中的protected identify() 被覆寫

{

print("I am Son.");

}

};

$obj = new Son();

$obj->getSalutation(); //輸出Hey! I am Son.

?>

//注: 在子類中沒有覆寫getSalutation(),但實際上仍然存在一個getSalutation().這個類中的$salutation和identify()

//與Son子類的執行個體中的getSalutation()方法動态綁定,是以調用Son的執行個體的getSalutation()方法,

//将調用Son類中的成員salutation及identify(),而不是父類中的成員salutation及identify().

Private 成員隻存在于它們所在的類内部. 不像public和protected成員那樣,PHP模拟靜态綁定。它輸出”Hello there! I am Father.”,盡管子類覆寫了salutation的值,腳本将this->salutation和目前類 Father綁定. 類似的原則應用于private方法identify()。

salutationn");

$this->identify();

}

private function identify()

{

print("I am Father.");

}

}

class Son extends Father

{

private $salutation = "Hey!";

private function identify()

{

print("I am Son.");

}

}

$obj = new Son();

$obj->getSalutation(); //輸出Hello there! I am Father.

?>

動 态綁定的好處是允許繼承類來改變父類的行為,同時可以保持父類的接口和功能,看例子. 由于使用了動态綁定,在deleteUser中被調用的isAuthorized的version 可以由對象的類型來确定。如果是一個普通的user,PHP調用User::isAuthorized會傳回FALSE.如果是一個 AuthorizedUser的執行個體,PHP調用AuthorizedUser::isAuthorized,将允許deleteUser順利執行。

//haohappy注:用一句話說清楚,就是對象類型與方法,屬性綁定. 調用一個父類與子類中都存在的方法或通路一個屬性時,會先判斷執行個體屬于哪種對象類型,再調用相應的類中的方法和屬性.

動态綁定的好處

name);

}

public function deleteUser($username) //删除使用者

{

if(!$this->isAuthorized())

{

print("You are not authorized.

n");

return(FALSE);

}

//delete the user

print("User deleted.

n");

}

}

class AuthorizedUser extends User //認證使用者

{

protected function isAuthorized() //覆寫isAuthorized()

{

return(TRUE);

}

}

$user = new User;

$admin = new AuthorizedUser;

//not authorized

$user->deleteUser("Zeev");

//authorized

$admin->deleteUser("Zeev");

?>

為什麼private的類成員模拟靜态綁定? 為了回答這個問題, 你需要回憶一下為什麼需要有private成員.什麼時候用它們來代替protected成員是有意義的?

private 成員隻有當你不想讓子類繼承改變或特殊化父類的行為時才用到,這種情況比你想像的要少, 通常來說,一個好的對象分層結構應當允許絕大多數功能被子類特殊化,改進,或改變—這是面向對象程式設計的基礎之一。一定的情況下需要 private方法或變量,例如當你确信你不想允許子類改變父類中的某個特定的部份。