Overload重载:重载是多态的基础,是方法名相同但根据参数不同做不同的处理,PHP是弱类型语言,不能直观的实现方法重载
Override覆盖:覆盖是子类继承父类方法并对齐进行重新构造,方法名相同即视为覆盖,且PHP5.3以后要求参数必须同父类相同,5.2以前可以不同
覆盖
能否覆盖由final关键字决定,final方法即为不可覆盖方法,但同时受父类的访问权限限制,覆盖方法访问权限不可高于父类
实现
实现基于继承,将父类中的抽象方法(没有函数体的函数声明)的方法功能实现出来,父类并没有此方法的功能,子类必须有权限拿到才能去实现方法功能(函数体),所以实现父类的抽象方法必须可访问到,父类抽象方法不可为private
1、父类某方法能否被子类重写与此方法的访问级别无关
public protected private对某方法内否被重写没有影响,能否被重写要看此方法是否被final修饰(final类不可被继承,final方法不可被重写)
2、但重写方法要受到访问级别的限制,即访问权限不可提升规定
(不仅仅是PHP,其他面向对象语言依然适用),访问权限只可以降低,不可以提升。
3、PHP重写父类方法时需要保持参数一致
虽然在 PHP 5.2 及以前没有此限制但我们还是以最高标准为原则,这也是风险控制的良好习惯,PHP并不会像C/C++一样在子类与父类方法名相同参数不一致时认为是对此方法的 多态重载,PHP没有直接的重载机制,所以必须保持方法名相同参数相同
4、重写不等于 实现
实现是抽象方法声明或者接口方法声明实现的场景,实现是继承关系,继承某抽象类or接口实现其方法,受访问权限的制约
重写并不需要访问到,重写是远远的站在子类中看父类的某个方法做一个自己的方法,不需要触碰到;实现则不同,实现属于继承,需访问到,这就是抽象方法不可被声明为private,接口比较特殊,必须为public的原因。
不要与抽象类中的抽象方法或者接口中的接口方法混淆,抽象方法和接口中的方法皆为方法声明,我们在子类继承于此抽象类或接口中对其实现,此为继承关系,你给我,我才可以去实现,所以抽象方法不可用private修饰,不然子类拿不到,而抽象方法又必须被子类继承实现,死锁了。
abstract class Abstract
{
//抽象方法必须为public protected 以使子类可以有权拿到去实现功能
//子类继承此抽象类并实现全部的抽象法发 且追寻访问权限的继承规定(不可提升)
abstract public function abstractPublicFunc();
abstract protected function abstractProtectedFunc();
}
class Test extends Abstract
{
public function abstractPublicFunc()
{
//权限不可提升 父类public所以这里只能是public
}
public/protected function abstractProtectedFunc()
{
//权限不可提升 父类protected所以这里不能为private 但可为protected或private
}
}
class Father
{
public function publicFunc()
{
//只能被重写为public
}
portected function protectedFunc()
{
//可重写为public/protected
}
private function privateFunc($args_1,$args_2....,$args_n)
{
//可重写为public/protected/private
}
}
class Child
{
public function publicFunc()
{
//访问权限不可提升 只能为public
}
public/portected function protectedFunc()
{
//访问权限不可提升 可为public/protected
}
//这里加上与父类相同的参数是想证明能不能重写和可否继承无关 private方法依然可被子类重写
public/portected/private function privateFunc($args_1,$args_2....,$args_n)
{
//private已经是最高访问权限 所以public/protected/private都可以
}
}