php 지연 정적 바인딩: 정의 시점을 기준으로 하지 않고 계산 중 실행 결과를 기준으로 하는 클래스 자체를 나타냅니다.
(1) 하위 클래스 인스턴스화 객체 $stu가 say 메소드를 호출하면 상위 클래스 Human 내에서 실행됩니다. 따라서 say()의 self::hei()는 상위 클래스의 hei() 메소드를 호출합니다.
(2) static::method name(): static 키워드를 사용하는 경우 먼저 하위 클래스에서 메서드를 검색하고, 찾을 수 없으면 상위 클래스에서 검색합니다.
사용 시나리오
먼저 다음 코드를 관찰하세요.
abstract class base { //do sth } class aClass extends base{ public static function create(){ return new aClass(); } } class bClass extends base{ public static function create(){ return new bClass(); } } var_dump(aClass::create()); var_dump(bClass::create());
출력:
object(aClass)#1 (0) { } object(bClass)#1 (0) { }
위의 aClass와 bClass는 추상 클래스 기반에서 상속되지만 create()는 두 하위 클래스 모두에서 동시에 구현됩니다. 시간 정적 방법. oop 아이디어에 따라 이 반복 코드는 상위 클래스 기반에서 구현되어야 합니다.
개선된 코드
abstract class base { public static function create(){ return new self(); } } class aClass extends base{ } class bClass extends base{ } var_dump(aClass::create()); var_dump(bClass::create());
현재 코드는 이전 아이디어와 일치하는 것 같습니다. create() 메서드는 상위 클래스에서 공유됩니다.
...에서 추상 클래스 기반을 인스턴스화할 수 없습니다.
안타깝게도 코드가 예상한 대로 실행되지 않는 것 같습니다. 상위 클래스의 self()는 상위 클래스 기반으로 구문 분석되며 해당 하위 항목에서 상속되지 않습니다. 친절한. 그래서 이 문제를 해결하기 위해 php5.3에서는 지연된 정적 바인딩이라는 개념이 도입되었습니다.
지연된 정적 바인딩
abstract class base { public static function create(){ return new static(); } } class aClass extends base{ } class bClass extends base{ } var_dump(aClass::create()); var_dump(bClass::create());
이 코드는 이전 코드와 거의 동일합니다. 차이점은 self가 static 키워드로 대체되어 상위 클래스가 아닌 하위 클래스로 해석된다는 점입니다. 해결될 수 있습니다. 발생한 문제는 PHP의 지연된 정적 바인딩입니다.
마지막으로 코드를 실행하여 원하는 최종 결과를 얻으세요.
위 내용은 PHP 지연 정적 바인딩이란 무엇입니까? 지연된 정적 바인딩 예제 코드에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!