new static()이든 new self()이든 새 개체는 새롭습니다. 이번 글에서는 PHP 객체지향에서 new self()와 new static()의 차이점을 주로 소개합니다. 도움이 필요한 친구들은 함께 살펴보도록 하겠습니다.
차이점은 다음과 같습니다.
먼저 결론을 명확히 하세요. PHP에서 self는 현재 호출되는 메서드를 정의하는 클래스를 가리키고, static은 현재 정적 메서드를 호출하는 클래스를 가리킵니다.
다음은 위의 결과를 증명하는 예입니다
class A { public static $_a = 'Class A'; public static function echoProperty() { echo self::$_a . PHP_EOL; } } class B extends A { public static $_a = 'Class B'; } $obj = new B(); B::echoProperty();//输出 Class A
이렇게 되는 이유는 현재 클래스를 정적으로 참조하기 위해 self:: 또는 __CLASS__를 사용하는 것이 호출된 메서드가 정의된 클래스에 따라 다르기 때문입니다. 클래스 A 위의 echoProperty 메서드는 다음과 같이 수정됩니다.
class A { public static $_a = 'Class A'; public static function echoProperty() { echo static::$_a . PHP_EOL; } } //再次调用B::echoProperty将输出 'CLASS B'
위의 첫 번째 예에서 볼 수 있듯이 하위 클래스가 상위 클래스의 정적 속성을 재정의한 후에도 상속된 메서드를 사용하여 상위 클래스의 정적 속성에 계속 액세스하는 것을 방지합니다. , PHP5.3 새로운 구문이 추가되었습니다. self 키워드 대신 static 키워드를 사용하여 static이 get_called_class()에서 반환된 동일한 클래스, 즉 현재 정적 메서드를 호출하는 클래스를 가리키는 후기 정적 바인딩입니다. . 이 키워드는 정적 메소드에 대한 액세스도 유효합니다.
다음 예에서는 new self()와 new static() 사이의 차이점을 더 잘 보여줍니다(후자는 호출 메서드의 현재 클래스를 가리키기 위해 PHP의 후기 정적 바인딩을 사용합니다)
class A { public static function get_self() { return new self(); } public static function get_static() { return new static(); } } class B extends A {} echo get_class(B::get_self()); // A echo get_class(B::get_static()); // B echo get_class(A::get_self()); // A echo get_class(A::get_static()); // A
관련 권장 사항:
위 내용은 PHP에서 new self()와 new static()의 차이점의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!