class A{
private $handle;
public funciton __construct(){
}
public function say($word){
if(!isset($handle)){
$this->__construct();
}
echo $word;
}
}
class B extends A{
private $word;
public funciton __construct($word){
$this->word = $word;
}
pulbi function call(){
$this->say($this->word);
}
}
$b = new B('hello');
$b->call();
運行這段代碼發現不會輸出 ‘hello’,
仔細看看,發現class A的say方法中 $this->__contruct()很有問題,本來是想調用class A的建構函式,實際上調用了B
這是得使用 self
這個關鍵字修飾的意義都表示"靜態",在PHP手冊中提到self, parent和static這幾個關鍵字,但實際上除了static是關鍵字以外,其他兩個均不是關鍵字,在手冊的關鍵字列表中也沒有這兩個關鍵字,要驗證這一點很簡單:
var_dump(self); // -> string(4) "self"
上面的代碼並沒有報錯,如果你把error_reporting(E_ALL)開啟,就能看到實際是什麼情況了:運行這段代碼會出現“ Notice: Use of undefined constant self - assumed 'self'“,也就是說PHP把self當成一個普通常量了,嘗試未定義的常量會把產量本身當成一個字串,例如上例的”self",不過同時會出一個NOTICE,這就是說self這個標示符並沒有什麼特殊的。
self是一個特殊類,它指向當前類,但只有在類定義內部才有效,它不止要求在類的定義內部,還要求在類的上下文環境,比如 new self()的時候,這時self就指向當前類。
因此class A的say方法 改為 self::__parent()即可