사용 시나리오
먼저 다음 코드를 관찰하세요.
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는 추상 클래스 기반에서 상속되지만, in 정적 메서드 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의 지연된 정적 바인딩입니다.
마지막으로 코드를 실행하여 원하는 최종 결과를 얻습니다.
object(aClass)#1 (0) { } object(bClass)#1 (0) { }
PHP 지연 정적 바인딩에 대한 단순한 이야기와 관련된 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!