|
復(fù)制代碼 代碼如下:
<?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()調(diào)用了A::x(),而B::x()覆蓋了A::x(),那么當(dāng)調(diào)用B::y()時,B::y()應(yīng)該調(diào)用A::x()還是 B::x()呢?在C++中,如果A::x()未被定義為虛函數(shù),那么B::y()(也就是A::y())將調(diào)用A::x(),而如果A::x()使用 virtual關(guān)鍵字定義成虛函數(shù),那么B::y()將調(diào)用B::x()。然而,在php5中,虛函數(shù)的功能是由 self 和 $this 關(guān)鍵字實(shí)現(xiàn)的。如果父類中A::y()中使用 self::x() 的方式調(diào)用了 A::x(),那么在子類中不論A::x()是否被覆蓋,A::y()調(diào)用的都是A::x();而如果父類中A::y()使用 $this->x() 的方式調(diào)用了 A::x(),那么如果在子類中A::x()被B::x()覆蓋,A::y()將會調(diào)用B::x()。
上例的運(yùn)行結(jié)果如下:
A::x() was called. A::y() was called. --
B::x() was called. A::z() was called.
virtual-function.php
復(fù)制代碼 代碼如下:
<?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( 'Hello' );
$b=new AnotherChildClass();
$b->say( 'Hello' );
php技術(shù):PHP5中虛函數(shù)的實(shí)現(xiàn)方法分享,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。