首頁 >後端開發 >php教程 >php 中虛函數的實作方法

php 中虛函數的實作方法

怪我咯
怪我咯原創
2017-07-14 10:50:424254瀏覽

函數為了重載和多型的需要,在基底類別中是由定義的,即便定義是空,所以子類別中可以重寫也可以不寫基底類別中的函數!

純虛函數在基底類別中是沒有定義的,必須在子類別中加以實現,很像java中的介面函數!

虛函數

引入原因:為了方便使用多型特性,我們常常需要在基底類別中定義虛函數。

而在php5中如何實作這個虛函數呢? 請看下面的程式碼: 

<?php 
class A { 
public function x() { 
echo "A::x() was called.\n"; 
} 
public function y() { 
self::x(); 
echo "A::y() was called.\n"; 
} 
public function z() { 
$this->x(); 
echo "A::z() was called.\n"; 
} 
} 
class B extends A { 
public function x() { 
echo "B::x() was called.\n"; 
} 
} 
$b = new B(); 
$b->y(); 
echo "--\n"; 
$b->z(); 
?>

該範例中,A::y()呼叫了A::x(),而B::x()覆蓋了A:: x(),那麼當呼叫B::y()時,B::y()應該呼叫A::x()還是B::x()呢?在C++中,如果A::x()未被定義為虛擬函數,那麼B::y()(也就是A::y())將會呼叫A::x(),而如果A::x ()使用virtual關鍵字定義成虛擬函數,那麼B::y()將會呼叫B::x()。然而,在PHP5中,虛函數的功能是由 self 和 $this 關鍵字實現的。如果父類別中A::y()中使用self::x() 的方式呼叫了A::x(),那麼在子類別中不論A::x()是否被覆蓋,A::y( )呼叫的都是A::x();而如果父類別中A::y()使用$this->x() 的方式呼叫了A::x(),那麼如果在子類別中A ::x()被B::x()覆蓋,A::y()將會呼叫B::x()。
上例的運作結果如下:

A::x() was called. A::y() was called. --
B::x() was called. A::z() was called.

virtual-function.php 

<?php 
class ParentClass { 
static public function say( $str ) { 
static::do_print( $str ); 
} 
static public function do_print( $str ) { 
echo "<p>Parent says $str</p>"; 
} 
} 
class ChildClass extends ParentClass { 
static public function do_print( $str ) { 
echo "<p>Child says $str</p>"; 
} 
} 
class AnotherChildClass extends ParentClass { 
static public function do_print( $str ) { 
echo "<p>AnotherChild says $str</p>"; 
} 
} 
echo phpversion(); 
$a=new ChildClass(); 
$a->say( &#39;Hello&#39; ); 
$b=new AnotherChildClass(); 
$b->say( &#39;Hello&#39; );

以上是php 中虛函數的實作方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn