除了限制訪問,訪問方式也決定哪個方法將被子類調用或哪個屬性將被子類訪問. 函數調用與函數本身的關聯,以及成員訪問與變量內存地址間的關系,稱為綁定.

在計算機語言中有兩種主要的 " /> 欧美日一区,欧美麻豆,伊人久久电影网

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

第九節 綁定 [9]


除了限制訪問,訪問方式也決定哪個方法將被子類調用或哪個屬性將被子類訪問. 函數調用與函數本身的關聯,以及成員訪問與變量內存地址間的關系,稱為綁定.

在計算機語言中有兩種主要的綁定方式―靜態綁定和動態綁定. 靜態綁定發生于數據結構和數據結構間,程序執行之前. 靜態綁定發生于編譯期, 因此不能利用任何運行期的信息. 它針對函數調用與函數的主體,或變量與內存中的區塊. 因為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 動態綁定
<?php
class Father
{
protected $salutation = "Hello there!"; file://問候

public function getSalutation()
{
print("$this->salutationn");
$this->identify();
}

protected function identify()
{
print("I am Father.<br>n");
}
};

class Son extends Father
{
protected $salutation = "Hey!"; file://父類中的protected $salutation 被覆寫

protected function identify() file://父類中的protected identify() 被覆寫
{
print("I am Son.<br>n");
}
};

$obj = new Son();
$obj->getSalutation(); file://輸出Hey! I 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
<?php
class Father
{
private $salutation = "Hello there!";

public function getSalutation()
{
print("$this->salutationn");
$this->identify();
}

private function identify()
{
print("I am Father.<br>n");
}
}

class Son extends Father
{
private $salutation = "Hey!";
private function identify()
{
print("I am Son.<br>n");
}
}

$obj = new Son();
$obj->getSalutation(); file://輸出Hello there! I am Father.
?>動態綁定的好處是允許繼承類來改變父類的行為,同時可以保持父類的接口和功能. 看例子6.12. 由于使用了動態綁定,在deleteUser中被調用的isAuthorized的version 可以由對象的類型來確定. 如果是一個普通的user,php調用User::isAuthorized會返回FALSE.如果是一個AuthorizedUser的實例,php調用AuthorizedUser::isAuthorized,將允許deleteUser順利執行.

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

Listing 6.12 動態綁定的好處
<?php
class User file://用戶
{
protected function isAuthorized() file://是否是驗證用戶
{
return(FALSE);
}

public function getName() file://獲得名字
{
return($this->name);
}

public function deleteUser($username) file://刪除用戶
{
if(!$this->isAuthorized())
{
print("You are not authorized.<br>n");
return(FALSE);
}

//delete the user
print("User deleted.<br>n");
}
}

class AuthorizedUser extends User file://認證用戶
{
protected function isAuthorized() file://覆寫isAuthorized()
{
return(TRUE);
}
}

$user = new User;
$admin = new AuthorizedUser;

//not authorized
$user->deleteUser("Zeev");

//authorized
$admin->deleteUser("Zeev");
?> 為什么private的類成員模擬靜態綁定? 為了回答這個問題, 你需要回憶一下為什么需要有private成員.什么時候用它們來代替protected成員是有意義的?

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

php技術第九節 綁定 [9],轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 281封信电视剧演员表| 流浪地球免费观看| 电视剧零下三十八度手机免费观看| 冲出堕落城完整高清版| 大海中的船原唱歌词| 张颜齐| 米娅华希科沃斯卡| juliet stevenson| 英雄重生| 真实游戏完整版高清观看| 抗日电影大突围完整版| 羞羞的铁拳演员表| 花宵道中1| 电视剧暗夜与黎明剧情介绍| 二年级最佳家长评语| 张学友电影全部作品| 浪人街| cctv16体育台节目表| 塔木德全文阅读免费| the girl next door| 蝴蝶视频在线观看| 李子京| 黑衣人| 白鹿电影| 电视剧《流金岁月》演员表| 野孩子美剧| 银行资信证明| 为奴12年| 职业目标评估| 拔萝卜电影版| 年会不能停豆瓣评分| 伦理<禁忌1| 廖凡和莫小棋主演的一半火焰一半海水 | 桐谷| 182tv福利视频| 欧美13| 电影喜剧明星演员表| 绿巨人3| 甄子丹100部经典电影| 裸体模特| 《桂花雨》课后题答案|