>백엔드 개발 >PHP 문제 >PHP 클래스 메소드 재작성 원칙은 무엇입니까?

PHP 클래스 메소드 재작성 원칙은 무엇입니까?

coldplay.xixi
coldplay.xixi원래의
2020-10-30 15:30:432171검색

PHP 클래스 메소드 재작성 원칙: 1. 최종 수정된 클래스 메소드는 하위 클래스에 의해 대체될 수 없습니다. 2. PHP가 상위 클래스 메소드를 대체하는지 여부는 메소드 이름이 일관성이 있는지 여부에 따라 판단됩니다. 또는 상위 클래스보다 느슨하며 액세스 수준을 업그레이드할 수 없습니다.

PHP 클래스 메소드 재작성 원칙은 무엇입니까?

PHP 클래스 메서드 재작성 원칙:

1. final로 수정된 클래스 메서드는 하위 클래스로 재정의될 수 없습니다.

final로 수정된 클래스 메서드는 final private 메서드가 있더라도 하위 클래스로 재정의될 수 없습니다. 하위 클래스는 여전히 재작성을 위해 정렬될 수 없습니다

class FinalMethod
{
    //可继承不可重写
    final public function finalPublic()
    {
        echo "can be inherited, but be overrided";
    }
    //可继承不可重写
    final protected function finalProtected()
    {
        echo "can be inherited, but be overrided";
    }
    //不可继承不可重写 虽然子类继承不到父类的private方法 但同时也会被final限制无法重写
    final private function finalPrivate()
    {
        echo "can not be inherited or be overrided";
    }
    //虽然不可继承 但子类里可重写此方法
    private function private()
    {
        echo "can not be inherited ,but be overrided";
    }
}
class Override extends FinalMethod
{
    //error
    public function finalPublic()
    {
    }
    //error
    protected function finalProtected()
    {
    }
    //error
    private function finalPrivate()
    {
    }
    //correct
    public/protected/private function private()
    {
        //子类继承父类重写父类方法时访问级别只能更加宽松 不可更为严格
    }
}

2. PHP가 상위 클래스 메소드를 재작성하는지 여부는 메소드 이름이 일치하는지 여부에 따라서만 판단됩니다(5.3 이후에는 상위 클래스 메소드의 매개변수 수가 다시 작성할 때 동일해야 함)

메소드 매개변수가 효과가 없다는 말은 아닙니다. PHP에는 오버로딩 메커니즘이 없으므로 메소드 이름으로만 판단됩니다. (C/C++는 동일한 메소드 이름을 가져야 할 뿐만 아니라 또한 동일한 매개변수), 재정의로 간주되고, 그렇지 않으면 오버로드됩니다. 즉, new 다형성 함수의 상태를 정의합니다. 메서드 이름이 동일하면 상위 클래스 메서드를 재정의하는 것으로 간주됩니다. 5.2는 다른 매개변수를 가질 수 있습니다. 5.3 이후에는 매개변수가 상위 클래스 메소드와 일치해야 하며 모두 상속된 액세스 수준의 규칙을 따라야 합니다.

class Father
{
    public function index($args_1)
    {
    }
}
class Child extends Father
{
    //5.3以后重写方法必须与父类保持参数个数相同
    public function index($args_1, $args_2)
    {
        //在C/C++中此为重载非重写,因为C/C++具有标准的多态机制,会因参数不同而视为某一方法的另一种态
        //but在php中此依然为重写 但5.3以后此为非法 必须与父类的方法参数个数保持一致
    }
    //5.3以后重写方法必须与父类保持参数个数相同
    private function index($args_1, $args_2)
    {
        //C/C++会因为参数不同于父类方法而视为重载,即新定义了一个函数的态,所以不会受到继承访问权限的限制
        //但php仍然会被视为对父类方法的重写,会受到继承访问权限的升降规则限制
    }
}

3. 액세스 수준은 상위 클래스의 액세스 수준과 같거나 느슨할 수만 있습니다.

부모 클래스의 공개 메소드는 보호 또는 비공개로 다시 작성할 수 없습니다. 그리고 protected 메서드는 더 엄격하지 않고 더 느슨할 수 있습니다

class Father
{
    public function index()
    {
    }
}
class Child extends Father
{
    protected/private function index()
    {
       //访问权限提升 错误
       //父类为public 则子类重写也只能为public
       //父类为protected 则子类可为public/protected
       //父类为private 则子类public/protected/private皆可
    }
}

사실 액세스 수준 상속 규칙에는 흥미로운 점이 많습니다

private은 상식적으로 상속될 수 없습니다. 하위 클래스는 이를 얻을 수 없지만 액세스 수준이 이미 가장 높으므로 마치 함수를 직접 재정의한 것처럼 하위 클래스에 private protected public을 작성할 수 있습니다. 5.2 이전 버전에서는 그럴 필요가 없기 때문에 이는 버전 5.2 이전에 특히 두드러졌습니다. 상위 클래스 메서드를 상속하고 재정의할 때는 동일한 수의 매개변수를 유지해야 합니다. 그러나 5.3 이후에는 이 영역의 매개변수 수가 상위 클래스와 동일해야 합니다. 상위 클래스의 추상 메서드나 인터페이스를 구현하는 메서드는 여전히 상속 관계이므로 액세스가 계속 추구됩니다. 수준에서는 업그레이드할 수 없는 규칙만 낮출 수 있습니다

그리고

추상 메서드는 다음과 같이 선언할 수 없습니다. 추상 수정 메서드는 상속 구현에 사용해야 하므로 공용 또는 보호만 가능합니다. 인터페이스의 메서드 선언은 공용이어야 하며, 인터페이스에서 선언된 메서드도 상속 및 구현되어야 하며 공용만 가능합니다. . 이 인터페이스의 구현 클래스는 공개 유형으로 다시 작성될 메소드도 지정합니다.

위 내용은 PHP 클래스 메소드 재작성 원칙은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.