>백엔드 개발 >PHP 문제 >PHP에서 후기 정적 바인딩을 사용하는 방법

PHP에서 후기 정적 바인딩을 사용하는 방법

醉折花枝作酒筹
醉折花枝作酒筹앞으로
2021-06-07 17:43:241252검색

이 글에서는 PHP에서 후기 정적 바인딩을 사용하는 방법을 소개합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

PHP에서 후기 정적 바인딩을 사용하는 방법

후기 정적 바인딩이란 무엇인가요? 사실, 우리는 이미 PHP의 정적 이전 기사에서 이에 대해 이야기했습니다. 오늘 우리는 이 개념을 다시 깊이 이해할 것입니다.

먼저 코드 조각을 통해 후기 정적 바인딩의 개념을 소개합니다.

class A
{
    public static function who()
    {
        echo __CLASS__, PHP_EOL;
    }
    public static function test()
    {
        self::who();
    }
}

class B extends A
{
    public static function who()
    {
        echo __CLASS__, PHP_EOL;
    }
}

B::test(); // A

이 코드에서는 self 키워드를 사용하여 test() 정적 메서드를 호출할 때 self는 Who()를 가리킵니다. 따라서 클래스 A의 메서드이므로 출력은 A입니다. 너무 흥분하지 마십시오. 이는 일반적인 정적 바인딩입니다. self 키워드가 호출하는 내용은 해당 키워드가 정의된 클래스에 따라 다릅니다. 즉, 상속 방법과 test() 메서드를 호출하는 데 어떤 하위 클래스가 사용되는지에 관계없이 self 키워드는 클래스 A의 who() 메서드를 호출합니다.

후기 정적 바인딩은 어떻습니까? 실제로 이는 인스턴스화된 클래스 객체와 약간 비슷합니다. 인스턴스화된 각 객체는 부모 클래스의 속성 메서드가 아니라 자신을 호출합니다. 일반적인 정적 호출은 이와 다르지만 실제로는 인스턴스화된 객체와 동일한 방식으로 정적 속성 메서드를 호출해야 할 필요가 있습니다. 이때 static 키워드를 사용하여 후기 정적 바인딩을 구현할 수 있습니다.

class C
{
    public static function who()
    {
        echo __CLASS__, PHP_EOL;
    }
    public static function test()
    {
        static::who();
    }
}

class D extends C
{
    public static function who()
    {
        echo __CLASS__, PHP_EOL;
    }
}

D::test(); // D

정적 키워드를 사용하면 여기서 클래스 D가 호출하는 test() 메서드 내부에서 호출되는 who()는 클래스 D 자체입니다.

공식 문서의 정의는 다음과 같습니다.

정적 메서드 호출을 수행할 때 클래스 이름은 명시적으로 지정됩니다(일반적으로 비정적 메서드 호출을 수행할 때 :: 연산자의 왼쪽에 있음). , 이는 객체가 속한 클래스를 명시적으로 지정하는 것입니다.

이 기능은 언어 내부 관점에서 "후기 정적 바인딩"이라고 합니다. "후기 바인딩"은 static::이 더 이상 현재 메서드가 정의된 클래스로 확인되지 않고 실제 런타임에 계산된다는 의미입니다. 정적 메서드 호출에 사용할 수 있으므로(그러나 이에 국한되지는 않음) "정적 바인딩"이라고도 합니다.

self 및 static 키워드 외에도 부모 클래스의 정적 콘텐츠를 호출하는 이 키워드의 의미는 분명합니다. 세 가지 키워드를 동시에 사용하여 테스트합니다:

class E
{
    public static function who()
    {
        echo __CLASS__, PHP_EOL;
    }
    public static function test()
    {
        self::who();
        static::who();
    }
}

class F extends E
{
    public static function who()
    {
        echo __CLASS__, PHP_EOL;
    }
}

class G extends F
{
    public static function who()
    {
        parent::who();
        echo __CLASS__, PHP_EOL;
    }
}

G::test();

// E
// F
// G

마지막으로 두 가지 PHP 메서드를 살펴보겠습니다. 하나는 현재 호출되고 있는 클래스를 가져오는 데 사용되는 get_called_class() 메서드입니다. 정적 메서드에서는 다른 비즈니스 논리 작업을 수행하기 위해 호출 메서드를 기반으로 현재 클래스가 어떤 클래스인지 확인할 수 있습니다. 다른 하나는 정적 메서드를 호출하는 데 사용되는ward_static_call() 메서드입니다.

class H
{
    public static function who()
    {
        echo __CLASS__ . ':' . join(',', func_get_args()), PHP_EOL;
    }
    public static function test()
    {
        echo get_called_class(), PHP_EOL;
        forward_static_call('who', 'a', 'b'); // xxx:a,b
        forward_static_call(['I', 'who'], 'c', 'd'); // I:c,d
        forward_static_call_array(['H', 'who'], ['e', 'f']); // H:e,f
    }
}

class I extends H
{
    public static function who()
    {
        echo __CLASS__ . ':' . join(',', func_get_args()), PHP_EOL;
    }
}

function who()
{
    echo 'xxx:' . join(',', func_get_args()), PHP_EOL;
}

H::test(); // H
// xxx:a,b
// I:c,d
// H:e,f
I::test(); // I
// xxx:a,b
// I:c,d
// H:e,f

forward_static_call()이 클래스 이름을 지정하지 않으면 전역 메서드가 호출된다는 점에 유의하세요. forward_static_call_array()는 배열을 사용하여 매개변수를 전달합니다.

테스트 코드:

https://github.com/zhangyue0503/dev-blog/blob/master/php/202001/source/%E5%90%8E%E6%9C%9F%E9%9D%99%E6%80%81%E7%BB%91%E5%AE%9A%E5%9C%A8PHP%E4%B8%AD%E7%9A%84%E4%BD%BF%E7%94%A8.php

추천 학습: php 비디오 튜토리얼

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

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제