>백엔드 개발 >PHP 튜토리얼 >PHP 지연 정적 바인딩에 대해 간략히 설명합니다.

PHP 지연 정적 바인딩에 대해 간략히 설명합니다.

高洛峰
高洛峰원래의
2016-12-26 16:09:491008검색

사용 시나리오

먼저 다음 코드를 관찰하세요.

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 중국어 웹사이트를 주목하세요!

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