>백엔드 개발 >PHP 튜토리얼 >PHP 클래스 메소드 재작성 원칙

PHP 클래스 메소드 재작성 원칙

高洛峰
高洛峰원래의
2017-03-31 16:26:032185검색

우리는 일상 업무에서 이 지식 포인트를 거의 사용하지 않을 수도 있지만, 여전히

PHP의 수업 방법 강조에 대해 명확하지 않은 지식 포인트를 찾아보고 싶습니다. 작성 규칙

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

final로 수정된 클래스 메서드는 하위 클래스로 재정의될 수 없습니다. 하위 클래스에 의해 재정의됨 Inherited 하위 클래스는 여전히 다시 작성을 위해 정렬될 수 없습니다

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++에서는 동일한 메서드 이름이 필요할 뿐만 아니라 매개변수가 동일한 경우에만 재정의된 것으로 간주됩니다. 그렇지 않으면 오버로딩, 즉 다형성으로 간주됩니다. 함수 가 새로 정의되었습니다.) 메서드 이름이 동일하면 상위 클래스 메서드를 재정의하는 것으로 간주됩니다. 5.2에서는 매개 변수가 상위 클래스 메서드와 일치해야 합니다. 상속된 액세스 수준의 규칙을 따릅니다.

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. 다시 작성할 때 액세스 수준은 상위 클래스의 액세스 수준과 같거나 느슨할 수만 있으며 늘릴 수 없습니다.

부모 클래스의 공개 메서드는 변경할 수 없습니다. 서브클래스에 의해 보호됨 또는 비공개로 다시 작성됩니다. 보호된 메서드는 비공개로 재정의될 수 없으며 완화되거나 엄격하지 않을 수 있습니다

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 이후에는 이 영역에 대한 제한이 강화되어 부모와 동일한 수의 매개 변수를 사용해야 합니다. class

참고:

하위 클래스가 상위 클래스의 추상 메서드를 구현하거나 특정 클래스가 인터페이스의 메서드를 구현하는 경우 실제로는 여전히 상속에 속합니다. 여전히 접근 수준을 낮출 수는 있지만 개선할 수는 없으며 추상 메서드를 비공개로 선언할 수 없다는 규칙을 추구하고 있습니다. 추상으로 수정된 메서드는 상속 및 구현에 사용해야 하므로 공개 또는 보호만 가능합니다. 인터페이스의 메서드 선언은 공개되어야 합니다. 인터페이스에서 선언된 메서드도 상속 및 구현되어야 하며, 이 인터페이스의 구현은 공개 유형으로 재정의되는 메서드도 지정합니다.

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