利用PHP的範圍解析運算子(::)

來源:互聯網
上載者:User
這篇文章主要介紹了關於利用PHP的範圍解析運算子(::),有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

今天 看joomla源碼的時候,才意識到。原來這個操作符還可以訪問類的非靜態方法啊。真的讓我吃驚不好。一直以為範圍解析運算子只能訪問類的static方法和static成員變數。

Scope Resolution Operator (::)
今天 看joomla源碼的時候,才意識到。原來這個操作符還可以訪問類的非靜態方法啊。真的讓我吃驚不好。一直以為範圍解析運算子只能訪問類的static方法和static成員變數。
如果各位不相信,下面有個簡單的小測試代碼可以證明這個。

class A{ private $_name = 'A'; function __construct(){ echo 'A construct <br />'; } function test(){ echo 'A test() <br />'; } } class B extends A{ private $_name = 'B'; function __construct(){ parent::__construct(); echo 'B construct <br />'; } function test(){ echo 'B test()'; } } A::test(); echo '######### <br />'; B::test();

這段代碼輸入的結果為:

A test() ######### B test()

雖然A類中的test()和B類中的test都不是 static方法,但是一樣可以用 “類名::方法名稱(參數列表)” 的樣式進行正確調用。他的效果和 new 一個類的執行個體,然後用這個執行個體調用
test方法是一個樣的。
但是,如果我需要在test方法中列印name屬性,直接用::來調用 會是怎麼個情況那.我們首先來修改下 上面的代碼。

class A{ private $_name = 'A'; function __construct(){ echo 'A construct <br />'; } function test(){ echo 'A test() <br />', $this->$_name,'<br />'; } } class B extends A{ private $_name = 'B'; function __construct(){ parent::__construct(); echo 'B construct <br />'; } function test(){ echo 'B test()', $this->_name,'<br />'; } } A::test(); echo '######### <br />'; B::test();

上面的代碼啟動並執行結果 如下:

Fatal error: Using $this when not in object context in D:\www\test\scoperefe.php on line 9 [html]

那有的朋友就說了。你壓根就沒有執行個體化類A,當然不能直接用$this->_name的方式來訪問成員變數$_name了,那麼,是不是修改成self::$_name就行了哪?
說幹就幹,下面把上面的代碼修改下

[code] class A{ private $_name = 'A'; function __construct(){ echo 'A construct <br />'; } function test(){ echo 'A test() <br />', self::$_name,'<br />'; } } class B extends A{ private $_name = 'B'; function __construct(){ parent::__construct(); echo 'B construct <br />'; } function test(){ echo 'B test()', $this->_name,'<br />'; } } A::test(); echo '######### <br />'; B::test();

再運行上面的代碼,結果如下:

A test() Fatal error: Access to undeclared static property: A::$_name in D:\www\test\scoperefe.php on line 9

哦,原來不能用self 關鍵字訪問當前類的非static方法。
現在,如果想正確的調用這個方法,有2個做法:
1、首先執行個體化類,然後用對象調用就可以直接使用$this->_name進行調用了;
2、將成員變數$_name設定為static;
上面的問題,相信大家都能夠正確的處理。
其實我真正想說的是:
如果一個方法可以不進行執行個體化就調用,那麼我們最好把這個方法使用static關鍵字修飾下。在實現方法的時候,只調用該類的static成員變數。這樣就不會出現上面遇到問題了。
如果一個方法沒有設定為static的方法。那麼,最安全的做法還是用執行個體對象進行調用更為安全,因為,說不定什麼時候就需要修改該方法的實現,在修改的時候,說不定就要調用該類中的
非static成員變數(因為,很大程度上在修改方法的實現的時候,已經忘記還有用類名直接調用這麼一說)。
個人愚見。

以上就是本文的全部內容,希望對大家的學習有所協助,更多相關內容請關注topic.alibabacloud.com!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.