먼저 결론을 명확히 하세요. 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에는 새로운 구문인 후기 정적 바인딩(Late static 바인딩)이 추가되었습니다. self 키워드는 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