前言
本文主要跟大家介紹了關于PHP面向對象中new self()與 new static()的區別,這兩個方法new出來的對象有什么區別呢,說白了就是new出來的到底是同一個類實例還是不同的類實例呢?下面話不多說了,來一起看看詳細的介紹吧。
區別如下:
首先闡明結論,在PHP中 self指向定義了當前被調用方法的類, static指向調用當前靜態方法的類。
接下來通過一個例子來證明上面的結果
class A { public static $_a = 'Class A'; public static function echoProperty() { echo self::$_a . PHP_EOL; } } class B extends A { public static $_a = 'Class B'; } $obj = new B(); B::echoProperty();//輸出 Class A
之所以會這樣是因為使用self:: 或者__CLASS__對當前類的靜態引用,取決于定義被調用方法所在的類,將上面Class A的方法echoProperty做一下修改變成:
class A { public static $_a = 'Class A'; public static function echoProperty() { echo static::$_a . PHP_EOL; } } //再次調用B::echoProperty將輸出 'CLASS B'
為了避免上面第一個例子中看到的子類重寫父類的靜態屬性后,使用繼承來的方法仍然訪問父類的靜態屬性, PHP5.3增加了一個新的語法:后期靜態綁定(Late static binding), 使用static關鍵字替代self關鍵字,使得static指向與get_called_class()返回的相同的類,即當前調用靜態方法的類, 該關鍵字對于靜態方法的訪問同樣有效。
下面的例子更好的說明了new self()和new static()之間的差異(后者使用了PHP的后期靜態綁定指向調用方法的當前類)
class A { public static function get_self() { return new self(); } public static function get_static() { return new static(); } } class B extends A {} echo get_class(B::get_self()); // A echo get_class(B::get_static()); // B echo get_class(A::get_self()); // A echo get_class(A::get_static()); // A
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對的支持。
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。