国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

PHP靜態綁定與動態綁定

瀏覽:2日期:2024-01-12 11:45:35

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

在計算機語言中有兩種主要的綁定方式?靜態綁定和動態綁定. 靜態綁定發生于數據結構和數據結構間,程序執行之前. 靜態綁定發生于編譯期, 因此不能利用任何運行期的信息. 它針對函數調用與函數的主體,或變量與內存中的區塊. 因為PHP是一種動態語言,它不使用靜態綁定. 但是可以模擬靜態綁定.

動態綁定則針對運行期產生的訪問請求,只用到運行期的可用信息. 在面向對象的代碼中,動態綁定意味著決定哪個方法被調用或哪個屬性被訪問,將基于這個類本身而不基于訪問范圍.

Public和protected成員的動作類似于PHP的前幾個版本中函數的動作,使用動態綁定. 這意味著如果一個方法訪問一個在子類中被覆寫的類成員,并是一個子類的實例,子類的成員將被訪問(而不是訪問父類中的成員).

看圖1. 這段代碼輸出” Hey! I am Son.” 因為當PHP調用getSalutation, 是一個Son的實例,是將Father中的salutation覆寫而來. 如果salutation是public的,PHP將產生相同的結果. 覆寫方法的操作很類似.在Son中,對于identify的調用綁定到那個方法.

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

動態綁定

<?php class Father { protected $salutation = 'Hello there!'; //問候

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

protected function identify() { print('I am Father.n'); } };

class Son extends Father { protected $salutation = 'Hey!'//父類中的protected $salutation 被覆寫

protected function identify();//父類中的protected identify() 被覆寫 { print('I am Son.n'); } };

$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模擬靜態綁定. 看例子圖2 . 它輸出”Hello there! I am Father.”,盡管子類覆寫了salutation的值. 腳本將this->salutation和當前類Father綁定. 類似的原則應用于private方法identify().

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.n'); } }

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

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

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

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

動態綁定的好處

<?php class User //用戶 { protected function isAuthorized(); //是否是驗證用戶 { return(FALSE); }

public function getName(); //獲得名字 { return($this->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方法或變量,例如當你確信你不想允許子類改變父類中的某個特定的部份.

標簽: PHP
主站蜘蛛池模板: 久久久国产一区二区三区丝袜 | 国产国语对白一级毛片 | 国产美女一级特黄毛片 | 一二三中文乱码亚洲乱码 | 国产精品三级a三级三级午夜 | 性感美女一级毛片 | 99久久精品久久久久久清纯 | 亚洲综合第一页 | 性色a| 亚洲人成亚洲精品 | 国产三级观看 | 亚洲人成日本在线观看 | 色多多最新地址福利地址 | 日本在线毛片视频免费看 | 日本国产精品 | 国产黄网 | 亚洲欧洲无码一区二区三区 | 五月天激激婷婷大综合蜜芽 | 免费aa在线观看 男人的天堂 | 亚洲国产日韩在线 | 在线观看一区二区三区四区 | 日韩欧美一二区 | 欧美精品国产制服第一页 | 国产深夜福利视频网站在线观看 | 国产精品99久久免费观看 | 一区二区日韩 | 丝袜足液精子免费视频 | 99精品在线观看 | 美美女高清毛片视频黄的一免费 | 国产麻豆交换夫妇 | 4455四色永久免费 | 日韩女人做爰大片 | 欧美在线小视频 | 亚洲在线不卡 | 91久久精品青青草原伊人 | 波多野结衣免费观看视频 | 欧美一级成人一区二区三区 | 久久久青草 | 亚洲一区二区精品视频 | 亚洲精品一区二区三区第四页 | 日本一级做人免费视频 |