這篇文章主要介紹了php面向對象程序設計中self與static的區別,結合實例形式分析了php面向對象程序設計中self與static的功能、以及在繼承過程中實現多態的區別,並總結了static靜態延遲綁定的原理,需要的朋友可以參考下
本文實例講述了php面向對象程序設計中self與static的區別。分享給大家供大家參考,具體如下:
1、假設我們有個Car類,它有2個方法:model()
和getModel()
。
class Car{ public function model(){ //這裏我們使用了關鍵字self self::getModel(); } protected function getModel(){ echo 'I am car'; } }
實例化後調用方法:
$car = new Car(); $car->model(); // 輸出:I am car
關鍵字self使得我們調用了Car類的getModel()方法,輸出了文本“I am car”。
2、添加一個新類作爲Car類的子類:
class Mercedes extends Car { protected function getModel() { echo "I am mercedes"; } } // 實例化後 調用model()方法 $mercedes = new Mercedes(); $mercedes->model();
我們知道子類會繼承父類的方法,我們在子類Mercedes中重寫了getModel()方法。
這時候實例化Mercedes類調用model()方法,會輸出字符串"I am car" 還是“I am mercedes”?
你可能會覺得結果是:I am mercedes。
但實際輸出是:
I am car
why?
3、關鍵字self的工作原理是:它會調用當前類的方法。
因爲model()
方法只在Car類中定義的,所以對self來說當前類就是Car類。self::getModel()
就是調用Car類中的getModel方法。
這似乎不是我們想要的,如何解決呢?
4、解決方案一:在Mercedes類中覆蓋model()
方法
class Mercedes extends Car { public function model(){ //這裏我們使用了關鍵字self self::getModel(); } protected function getModel() { echo "I am mercedes"; } } // 實例化後 調用model()方法 $mercedes = new Mercedes(); $mercedes->model(); // 輸出:I am mercedes
但這肯定不是好辦法啊,方法都重寫了,還繼承個毛啊。
5、解決方案二:把self關鍵字換成static
class Car{ public function model(){ //這裏我們使用了關鍵字static static::getModel(); } protected function getModel(){ echo 'I am car'; } }
我們只是將Car類中的self替換成了static,並未對Mercedes類作修改。
此時我們調用:
$mercedes = new Mercedes(); $mercedes->model(); // 輸出:I am mercedes
6、小結
在php5.3中加入了一個新特性,叫做延遲靜態綁定。可以幫我們實現多態。
簡單說,延遲靜態綁定意味着,當我們使用static關鍵字調用一個繼承方法時,它將在運行時才綁定調用類。
更多關於PHP相關內容感興趣的讀者可查看本站專題:《php面向對象程序設計入門教程》、《PHP數組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧彙總》
希望本文所述對大家PHP程序設計有所幫助。