本文目錄一覽:
PHP繼承的問題,調用父類的方法this指向問題。
我來說一說:
【一】…………public(僅有)屬性和方法的繼承…………
class a{
public $var = ‘var a br/’;
public function m(){
echo ‘fun a br/’;
}
public function run(){
echo $this-var;
$this-m();
}
}
class b extends a{
public $var = ‘var b br/’;
public function m(){
echo ‘fun b br/’;
}
}
$li = new b();
$li-run();
echo ‘hr’;
var_dump($li);
輸出:
var b
fun b
————————————————————————————
object(b)[1]
public ‘var’ = string ‘var b br/’ (length=11)
在這段代碼中所表示的,是我們常見的一種繼承方式,同為公有屬性的$var 和公有方法m()
在這裡,$var和m()都被繼承並覆寫,實例化過後,內存中只有一個$var實例,通過var_dump($li);我們可以看到它。
【二】…………private(私有)屬性和方法的繼承…………
class a{
private $var = ‘var a br/’;
private function m(){
echo ‘fun a br/’;
}
public function run(){
echo $this-var;
$this-m();
var_dump($this);
echo ‘br/br/’;
}
}
class b extends a{
private $var = ‘var b br/’;
private function m(){
echo ‘fun b br/’;
}
public function run(){
echo $this-var;
$this-m();
var_dump($this);
echo ‘br/br/’;
parent::run();
}
}
$li = new b();
$li-run();
echo ‘hr’;
var_dump($li);
輸出:
var b
fun b
object(b)[1]
private ‘var’ = string ‘var b br/’ (length=11)
private ‘var’ (a) = string ‘var a br/’ (length=11)
.
.
var a
fun a
object(b)[1]
private ‘var’ = string ‘var b br/’ (length=11)
private ‘var’ (a) = string ‘var a br/’ (length=11)
.
————————————————————————————————
object(b)[1]
private ‘var’ = string ‘var b br/’ (length=11)
private ‘var’ (a) = string ‘var a br/’ (length=11)
這個時候,我們可以看到,在調用run方法時,首先它會調用到b類的私有屬性$var 和私有方法m(),隨後,又使用parent::run()調用父類的run()方法,我們可以看到,父類的run()方法調用後,它所調用的屬性和方法,都是a類的兩個私有屬性和方法,這種形式,和你的問題一致;
而它與$this指向無關,我們可以在這裡看到,兩個$this都是指向b類。
而最有意思的是,在$li句柄中,我們卻看到了兩個屬性!一個是b類的屬性,一個是a類的屬性,這兩個屬性同時存在着,那麼,私有方法也自然是同時存在着。
【三】…………私有屬性和方法能不能被繼承…………
class a{
private $var = ‘var a br/’;
private function m(){
echo ‘fun a br/’;
}
}
class b extends a{
public function run(){
echo $this-var;
$this-m();
}
}
$li = new b();
$li-run();
輸出:
Notice: Undefined property: b::$var in E: … on Line 9
Fatal error: Call to private method a::m() from context ‘b’ in E: … on Line 10
這可以證明,私有屬性和方法,無法被繼承,所以,你的代碼示例中所說,將a類的m()方法更改為private後,會顯示aa的屬性,也就可以理解明白了。
PHP類繼承的問題,子類繼承父類,實例化子類,先執行父類還是先執行子類?
不是這個意思。所謂「實例化子類的對象前要先實例化父類中的內容,為父類初始化」,是指當子類正在實例化時,總是鏈式調用父類構造方法初始化父類空間。換句話說,子類的構造方法必須先調用父類的構造方法,完了才能幹別的初始化工作。如果子類沒有顯式調用語句,編譯器會隱式幫你加上。
如:
public class A{ public A() { }}public class B extends A{ public B() { }}等價於:
public class A{ public A() { super();//這裡實際上是Object(); //其他初始化工作 }}public class B extends A{ public B() { super();//這裡實際上是A(); //其他初始化工作 }}另外,如果有這種情況:
public class A{ X x=new X(); public A() { }}public class B extends A{ Y y=new Y(); public B() {//這是類A空間里的字段都已經初始化完畢。 }}在成員y被賦值之前,x一定已經存在。換句話說,X x=new X();一定先於Y y=new Y();執行。
php中靜態類的繼承
樓主這個問題跟靜態沒有多大關係,主要是繼承的概念沒有搞清楚,繼承一個類是將子類擁有了調用父類的方法和屬性的權利,並不是說將父類的方法複製到了子類中self方法相當於當前類的指針,你那樣調用相當於寫了
public static function test() {
parent::who();
}
這樣的代碼,所以才會出現那樣的結果
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/152931.html
微信掃一掃
支付寶掃一掃