>  기사  >  백엔드 개발  >  PHP OOP 이후의 늦은 정적 바인딩

PHP OOP 이후의 늦은 정적 바인딩

*文
*文원래의
2017-12-27 10:28:121383검색

이 글에서는 주로 PHP 객체지향의 사후 정적 바인딩 기능을 소개합니다. 이 기사에서는 상속 범위에서 정적으로 호출되는 클래스를 참조하는 문제를 해결하는 데 주로 사용되는 PHP의 최신 정적 바인딩 기능을 소개합니다. 그것이 모두에게 도움이 되기를 바랍니다.

이 기사에서는 PHP 후기 정적 바인딩 기능을 소개합니다. 주로 상속 범위에서 정적으로 호출된 클래스를 참조하는 문제를 해결하는 데 사용됩니다.

먼저 다음 예를 살펴보세요.

class Person
{
 
    public static function status()
    {
        self::getStatus();
    }
 
    protected static function getStatus()
    {
        echo "Person is alive";
    }
 
}
 
class Deceased extends Person
{
 
    protected static function getStatus()
    {
        echo "Person is deceased";
    }
 
}
 
Deceased::status(); //Person is alive

분명히 결과는 우리가 예상한 것과 다릅니다. 이는 self::가 실행 중인 클래스가 아니라 정의된 클래스에 의존하기 때문입니다. 이 문제를 해결하려면 상속된 클래스에서 status() 메서드를 재정의할 수 있습니다. 더 나은 해결책은 PHP 5.3에 후기 정적 바인딩 기능이 추가된 것입니다.

class Person
{
 
    public static function status()
    {
        static::getStatus();
    }
 
    protected static function getStatus()
    {
        echo "Person is alive";
    }
 
}
 
class Deceased extends Person
{
 
    protected static function getStatus()
    {
        echo "Person is deceased";
    }
 
}
 
Deceased::status(); //Person is deceased

정적::은 더 이상 현재 클래스를 가리키지 않는 것을 볼 수 있습니다. 실제로 런타임에 계산되어 최종 클래스의 모든 속성을 강제로 가져옵니다.

따라서 self::를 사용하지 않는 것이 좋습니다. 앞으로는 static::

을 사용하세요. 관련 권장 사항:

php 객체 지향 트랜잭션 스크립트 모드

PHP 객체- 최종 클래스와 최종 메소드

PHP 객체지향 상세설명_PHP 튜토리얼

위 내용은 PHP OOP 이후의 늦은 정적 바인딩의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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