php面向對象程序設計中self與static的區別分析

這篇文章主要介紹了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程序設計有所幫助。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章