*
---------------------------------------------- ---------------------------------
| = 本文為Haohappy讀>
| = 中Classes and Objects一章的筆記
| = 翻譯為主個人心得
| = 為避免可能發生的不必要的麻煩請勿批評、謝謝希望能與所有PHP愛好者共同進步!
| = PHP5研究中心: http://blog.csdn.net/haohappy2004
------------------ -------------------------------------------------- -----------
*/
第九節--綁定
除了限制訪問,訪問方式也決定哪個方法將被子類調用或哪個屬性將被子類訪問. 函數呼叫與函數本身的關聯,以及成員存取與變數記憶體位址間的關係,稱為綁定.
在電腦語言中有兩種主要的綁定方式—靜態綁定和動態綁定. 靜態綁定發生於資料結構和資料結構間,程式執行之前. 靜態綁定發生於編譯期, 因此不能利用任何運行期的資訊. 它針對函數呼叫與函數的主體,或變數與記憶體中的區塊.因為PHP是一種動態語言,它不使用靜態綁定. 但是可以模擬靜態綁定.
動態綁定則針對運行期產生的訪問請求,只用到運行期的可用信息. 在面向對象的程式碼中,動態綁定意味著決定哪個方法被呼叫或哪個屬性被存取,將基於這個類別本身而不基於存取範圍.
Public和protected成員的動作類似於PHP的前幾個版本中函數的動作,使用動態綁定. 這表示如果一個方法存取一個在子類別中被覆寫的類別成員,並且是一個子類別的實例,子類別的成員將被存取(而不是存取父類別中的成員) .
看範例6.10. 這段程式碼輸出」 Hey! I am Son.」 因為當PHP呼叫getSalutation, 是一個Son的實例,是將Father中的salutation覆寫而來. 如果salutation是public的,PHP將產生相同的結果. 覆寫方法的操作很類似.在Son中,對於identify的呼叫綁定到那個方法.
即使在子類中訪問方式被從protected削弱成public, 動態綁定仍然會發生. 依照存取方式使用的原則,增強對於類別成員的存取限制是不可能的. 所以把存取方式從public改變成protected不可能進行.
Listing 6.10 Dynamic binding 動態綁定
複製碼 代碼如下:
class Father
ello there!"; //問候
public function getSalutation()
{ $this->identify();
}
ted
{
print("I am Father.
n"); 🎜> class Son extends Father
{
protected $salutation = protected $salutation = "Hey !"; //父類別中的protected $salutation 被覆寫
protected function identify()
print("I am Son.
n");
}
};
$obj = am Son.
?>
//註: 在子類別中沒有覆寫getSalutation(),但實際上仍然存在一個getSalutation().這個類別中的$salutation和identify()
//與Son子類別的實例中的getSalutation( )方法動態綁定,所以呼叫Son的實例的getSalutation()方法,
//將呼叫Son類別中的成員salutation及identify(),而不是父類別中的成員salutation及identify().
Private成員只存在於它們所在的類內部. 不像public和protected成員那樣,PHP模擬靜態綁定. 看例子6.11. 它輸出”Hello there! I am Father.”,儘管子類覆寫了salutation的值. 腳本將this->salutation和當前類別Father綁定. 類似的原則應用於private方法identify().
Listing 6.11 Binding and private members
代碼如下:
class Father
{ 🎜> public function getSalutation()
{
print("$this->salutationn");
private function identify()
{
Father.
n");
}
}
class S private $salutation = "Hey!";
private function identify()
{
print("I am Son.
n"); $obj = new Son();
$obj->getSalutation(); / /輸出Hello there! I am Father.
?>
動態綁定的好處是允許繼承類別來改變父類別的行為,同時可以保持父類別的介面和功能. 看範例6.12. 由於使用了動態綁定,在deleteUser中被呼叫的isAuthorized的version 可以由物件的型別來決定. 如果是一個普通的user,PHP呼叫User::isAuthorized會回傳FALSE.如果是一個AuthorizedUser的實例,PHP呼叫AuthorizedUser:: isAuthorized,將允許deleteUser順利執行.
//haohappy註:用一句話說清楚,就是物件類型與方法,屬性綁定. 呼叫一個父類別與子類別中都存在的方法或存取一個屬性時,會先判斷實例屬於哪一個物件型別,再呼叫對應的類別中的方法與屬性.
Listing 6.12 動態綁定的好處
複製程式碼
複製程式碼
複製程式碼複製程式碼
複製程式碼程式碼如下:
class User //使用者
{
{
return(FALSE);
}
public function getName() //取得名字
{
}
public function deleteUser($username) //移除使用者
> if(!$this->isAuthorized())
{
print("You are not authorized.
n");
return(FALSE);
}
/ /delete the user
print("User deleted.
n");
izedUser extends User //認證使用者
{
protected function isAuthorized( ) //覆蓋isAuthorized()
{
$user = new User;
$admin = new AuthorizedUser;
/ /not authorized
$user->deleteUser("Zeev");
//authorized
$admin->deleteUser("Zeev");
?>
為什麼private的類成員模擬靜態綁定? 為了回答這個問題, 你需要回憶一下為什麼需要有private成員.什麼時候用它們來代替protected成員是有意義的?
private成員只有當你不想讓子類繼承改變或特殊化父類的行為時才用到. 這種情況比你想像的要少. 通常來說,一個好的對象分層結構應當允許絕大多數功能被子類特殊化,改進,或改變—這是面向對象程式設計的基礎之一. 一定的情況下需要private方法或變數,例如當你確信你不想允許子類別改變父類別中的某個特定的部分.
http://www.bkjia.com/PHPjc/316941.html
www.bkjia.com
true
http: //www.bkjia.com/PHPjc/316941.htmlTechArticle* ----------------------- -------------------------------------------------- ------ |=本文為Haohappy讀CorePHPProgramming |=中ClassesandObjects一章的筆記|=翻譯為主個人...