本文實例講述了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程序設計有所幫助。
您可能感興趣的文章:- PHP的new static和new self的區別與使用
- PHP面向對象程序設計中的self、static、parent關鍵字用法分析
- PHP面向對象中new self()與 new static()的區別淺析
- 淺談PHP中new self()和new static()的區別
- PHP Class self 與 static 異同與使用詳解