繼承已為大家所熟知的一個(gè)程序設計特性,PHP 的對象模型也使用了繼承。繼承將會(huì )影響到類(lèi)與類(lèi),對象與對象之間的關(guān)系。
比如,當擴展一個(gè)類(lèi),子類(lèi)就會(huì )繼承父類(lèi)所有 public 和 protected 的方法,屬性和常量。除非子類(lèi)覆蓋了父類(lèi)的方法,被繼承的方法都會(huì )保留其原有功能。
繼承有助于功能的設計和抽象,在實(shí)現類(lèi)似的對象、增加新功能時(shí),無(wú)須重復編寫(xiě)這些公用的功能。
子類(lèi)無(wú)法訪(fǎng)問(wèn)父類(lèi)的私有方法。因此,子類(lèi)無(wú)需考慮正常的繼承規則而重新實(shí)現私有方法。
然而,在 PHP 8.0.0 之前, final
和 static
的限制會(huì )應用于 private 方法。
從 PHP 8.0.0 開(kāi)始,僅 private final
的構造器是唯一受限的 private 方法;
想要“禁用”構造器,我們通常用靜態(tài)工廠(chǎng)方法作為代替。
方法,屬性和常量的 可見(jiàn)性
可以放寬,例如 protected
方法可以標記為 public
,
但不能增加限制,例如標記 public
屬性為 private
。
注意:
除非使用了自動(dòng)加載,否則一個(gè)類(lèi)必須在使用之前被定義。如果一個(gè)類(lèi)擴展了另一個(gè),則父類(lèi)必須在子類(lèi)之前被聲明。此規則適用于類(lèi)繼承其它類(lèi)與接口。
注意:
It is not allowed to override a read-write property with a readonly property or vice versa.
<?php
class A {
public int $prop;
}
class B extends A {
// Illegal: read-write -> readonly
public readonly int $prop;
}
?>
示例 #1 繼承示例
<?php
class Foo
{
public function printItem($string)
{
echo 'Foo: ' . $string . PHP_EOL;
}
public function printPHP()
{
echo 'PHP is great.' . PHP_EOL;
}
}
class Bar extends Foo
{
public function printItem($string)
{
echo 'Bar: ' . $string . PHP_EOL;
}
}
$foo = new Foo();
$bar = new Bar();
$foo->printItem('baz'); // 輸出: 'Foo: baz'
$foo->printPHP(); // 輸出: 'PHP is great'
$bar->printItem('baz'); // 輸出: 'Bar: baz'
$bar->printPHP(); // 輸出: 'PHP is great'
?>