• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
  • 第九節--綁定 -- Classes and Objects in PHP5 [9]

    發表于:2007-05-17來源:作者:點擊數: 標簽:Classes第九andObjects綁定
    /* +-------------------------------------------------------------------------------+ | = 本文為Haohappy讀Core PHP Programming | = 中Classes and Objects一章的筆記 | = 翻譯為主+個人心得 | = 為避免可能發生的不必要的麻煩請勿轉載,謝謝 | = 歡迎


    /*
    +-------------------------------------------------------------------------------+
    | = 本文為Haohappy讀<<Core PHP Programming>>
    | = 中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 動態綁定
    php><?php 
       class Father 
       { 
           protected $salutation = "Hello there!"; //問候 
    
           public function getSalutation() 
           { 
               print("$this->salutation\n"); 
               $this->identify(); 
           } 
    
           protected function identify() 
           { 
               print("I am Father.<br>\n"); 
           } 
       }; 
    
       class Son extends Father 
       { 
           protected $salutation = "Hey!";  //父類中的protected $salutation 被覆寫 
    
           protected function identify()    //父類中的protected identify() 被覆寫 
           { 
               print("I am Son.<br>\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模擬靜態綁定. 看例子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->salutation\n"); 
               $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(); //輸出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 //用戶 
       { 
           protected function isAuthorized()  //是否是驗證用戶 
           { 
               return(FALSE); 
           } 
    
           public function getName()  //獲得名字 
           { 
               return($this->name); 
           } 
    
           public function deleteUser($username) //刪除用戶 
           { 
               if(!$this->isAuthorized()) 
               { 
                   print("You are not authorized.<br>\n"); 
                   return(FALSE); 
               } 
    
               //delete the user 
               print("User deleted.<br>\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網站所有,未經本站同意,禁止任何商業轉載。非盈利網站及個人網站轉載請注明出處,謝謝合作!

    原文轉自:http://www.kjueaiud.com

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>