PHP 클래스 메소드 재작성 원칙: 1. 최종 수정된 클래스 메소드는 하위 클래스에 의해 대체될 수 없습니다. 2. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!