您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關PHP5.0動態怎么綁定以及為什么private的類成員模擬靜態綁定,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
在計算機語言中有兩種主要的綁定方式—靜態綁定和動態綁定。靜態綁定發生于數據結構和數據結構間,程序執行之前.靜態綁定發生于編譯期,因此不能利用任何運行期的信息。它針對函數調用與函數的主體,或變量與內存中的區塊。因為PHP是一種動態語言,它不使用靜態綁定。但是可以模擬靜態綁定。
PHP5.0動態怎么綁定
動態綁定則針對運行期產生的訪問請求,只用到運行期的可用信息。在面向對象的代碼中,動態綁定意味著決定哪個方法被調用或哪個屬性被訪問,將基于這個類本身而不基于訪問范圍。
Public和protected成員的動作類似于PHP的前幾個版本中函數的動作,使用動態綁定。這意味著如果一個方法訪問一個在子類中被覆寫的類成員,并是一個子類的實例,子類的成員將被訪問(而不是訪問父類中的成員)。
看例子6.10.這段代碼輸出”Hey!IamSon.”因為當PHP調用getSalutation,是一個Son的實例,是將Father中的salutation覆寫而來.如果salutation是public的,PHP將產生相同的結果.覆寫方法的操作很類似。在Son中,對于identify的調用綁定到那個方法。
即使在子類中訪問方式被從protected削弱成public,動態綁定仍然會發生.按照訪問方式使用的原則,增強對于類成員的訪問限制是不可能的,所以把訪問方式從public改變成protected不可能進行。
Listing6.10Dynamicbinding動態綁定
classFather
{
protected$salutation="Hellothere!";//問候
publicfunctiongetSalutation()
{
print("$this->salutationn");
$this->identify();
}
protectedfunctionidentify()
{
print("IamFather.
n");
}
};
classSonextendsFather
{
protected$salutation="Hey!";//父類中的protected$salutation被覆寫
protectedfunctionidentify()//父類中的protectedidentify()被覆寫
{
print("IamSon.
n");
}
};
$obj=newSon();
$obj->getSalutation();//輸出Hey!IamSon.
?>
//注:在子類中沒有覆寫getSalutation(),但實際上仍然存在一個getSalutation().這個類中的$salutation和identify()
//與Son子類的實例中的getSalutation()方法動態綁定,所以調用Son的實例的getSalutation()方法,
//將調用Son類中的成員salutation及identify(),而不是父類中的成員salutation及identify().
Private成員只存在于它們所在的類內部.不像public和protected成員那樣,PHP模擬靜態綁定.看例子6.11。它輸出”Hellothere!IamFather.”,盡管子類覆寫了salutation的值,腳本將this->salutation和當前類Father綁定.類似的原則應用于private方法identify()。
Listing6.11Bindingandprivatemembers
classFather
{
private$salutation="Hellothere!";
publicfunctiongetSalutation()
{
print("$this->salutationn");
$this->identify();
}
privatefunctionidentify()
{
print("IamFather.
n");
}
}
classSonextendsFather
{
private$salutation="Hey!";
privatefunctionidentify()
{
print("IamSon.
n");
}
}
$obj=newSon();
$obj->getSalutation();//輸出Hellothere!IamFather.
?>
動態綁定的好處是允許繼承類來改變父類的行為,同時可以保持父類的接口和功能,看例子6.12.由于使用了動態綁定,在deleteUser中被調用的isAuthorized的version可以由對象的類型來確定。如果是一個普通的user,PHP調用User::isAuthorized會返回FALSE.如果是一個AuthorizedUser的實例,PHP調用AuthorizedUser::isAuthorized,將允許deleteUser順利執行。
//haohappy注:用一句話說清楚,就是對象類型與方法,屬性綁定.調用一個父類與子類中都存在的方法或訪問一個屬性時,會先判斷實例屬于哪種對象類型,再調用相應的類中的方法和屬性.
Listing6.12動態綁定的好處
classUser//用戶
{
protectedfunctionisAuthorized()//是否是驗證用戶
{
return(FALSE);
}
publicfunctiongetName()//獲得名字
{
return($this->name);
}
publicfunctiondeleteUser($username)//刪除用戶
{
if(!$this->isAuthorized())
{
print("Youarenotauthorized.
n");
return(FALSE);
}
//deletetheuser
print("Userdeleted.
n");
}
}
classAuthorizedUserextendsUser//認證用戶
{
protectedfunctionisAuthorized()//覆寫isAuthorized()
{
return(TRUE);
}
}
$user=newUser;
$admin=newAuthorizedUser;
//notauthorized
$user->deleteUser("Zeev");
//authorized
$admin->deleteUser("Zeev");
?>
為什么private的類成員模擬靜態綁定
為了回答這個問題,你需要回憶一下為什么需要有private成員.什么時候用它們來代替protected成員是有意義的?
private成員只有當你不想讓子類繼承改變或特殊化父類的行為時才用到,這種情況比你想像的要少,通常來說,一個好的對象分層結構應當允許絕大多數功能被子類特殊化,改進,或改變—這是面向對象編程的基礎之一。一定的情況下需要private方法或變量,例如當你確信你不想允許子類改變父類中的某個特定的部份。
以上就是PHP5.0動態怎么綁定以及為什么private的類成員模擬靜態綁定,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。