php中self和static的差異:self只能引用目前類別(current class)中的方法,而static允許函數呼叫在運行時綁定呼叫類別(calling class)中的方法。
本教學操作環境:windows7系統、PHP7.1版,DELL G3電腦
透過一些範例,我們可以很容易看出self和static的差異。假設我們有class Car – 它有兩個方法,model和getModel。注意,這裡我們使用了關鍵字self。
class Car { public static function model() { self::getModel(); } protected static function getModel() { echo "I am a Car!"; } }
呼叫靜態方法
Car::model();
得到輸出
I am a Car!
關鍵字self使得我們呼叫了class Car的getModel方法,輸出了文字「I am a Car!」。
下面我們新增一個新的類,class Mercedes, 它繼承自class Car,程式碼如下:
class Mercedes extends Car{ protected static function getModel() { echo "I am a Mercedes!"; } }
當我們呼叫Mercedes::model()時,猜猜結果是什麼?
可能你覺得結果會是:
I am a Mercedes!
但實際輸出是:
I am a Car!
這是為什麼呢?
關鍵字「self」的工作原理是:它會呼叫目前類別(current class)的方法。因為model方法只在class Car中定義的,所以對它來說目前類別就是class Car。 model中的self::getModel(),呼叫的自然也就是class Car中的getModel方法。
這個行為似乎不是我們想要的,它不符合物件導向的設計原則。如何解決呢?可以使用關鍵字static。
在PHP5.3中,加入了一個新的特性,叫做延遲靜態綁定。它可以幫我們實現多態,解決上面的問題。簡單來說,延遲靜態綁定意味著,當我們用static關鍵字呼叫繼承方法時,它將在運行時綁定呼叫類別(calling class)。在上面的範例中,如果我們使用延遲靜態綁定(static),意味當我們呼叫「Mercedes::model();」時,class Mercedes中的getModel方法將會被呼叫。因為Mercedes是我們的呼叫類別。
class Car{ public static function model() { static::getModel(); } protected static function getModel() { echo "I am a Car!"; } }
我們只是將class Car中的self替換成了static,並未對class Mercedes作修改。
現在我們呼叫
Mercedes::model();
得到輸出
I am a Mercedes!
注意,php 5.3之前的版本無法使用延遲靜態綁定。如果嘗試在php 5.3以下的版本執行上面的例子,將會報錯。
現在我們將範例中的self用static替換,可以看到,兩者的差別在於:self引用的是目前類別(current class)中的方法,而static允許函數呼叫在運行時綁定呼叫類別(calling class)中的方法。
推薦學習:《PHP影片教學》
以上是php中self和static的差別是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!