먼저 결론을 명확히 하세요. 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 관련 지식은 PHP를 방문하세요. 중국사이트!
위 내용은 PHP 객체 지향에서 new self()와 new static()의 차이점의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!