사용 시나리오
먼저 다음 코드를 관찰하세요.
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 키워드로 대체되고 static이 적용된다는 점입니다. 상위 클래스가 아닌 하위 클래스로 해결하면 위에서 발생한 문제를 해결할 수 있습니다. 이는 PHP의 지연된 정적 바인딩입니다.
마지막으로 코드를 실행하여 원하는 최종 결과를 얻습니다.
object(aClass)#1 (0) { } object(bClass)#1 (0) { }
위에서는 PHP 지연 정적 바인딩에 대한 간략한 설명을 포함하여 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.