PHP static 키워드는 클래스에서 정적 바인딩을 지연하고 함수의 변수를 수정하는 데 사용할 수 있는 정적 메서드와 properties를 정의하는 데 사용됩니다.
1: 먼저 함수에서 static을 사용하는 방법에 대해 이야기해 보겠습니다.
function add(){ static $a = 0; echo $a,"<br />"; $a++; }
여기서 static의 역할은 C의 static 역할과 유사하므로 $a 변수가 ()가 처음 호출될 때 초기화될 때만 추가되는데, 정적 변수를 정의할 때 초기값을 할당할 필요가 없고 초기값을 부여할 수 있지만 할당할 때 주의해야 합니다. 초기값을 지정하면 표현식을 사용하거나 함수를 호출할 수 없습니다. 그렇지 않으면 오류가 보고됩니다.
또 주목해야 할 점은 정적 변수는 다음과 같이 참조를 저장하지 않는다는 점입니다.
function get_obj_ref(){ static $obj = null; echo 'Ststic obj:',"<br />"; var_dump($obj); if(is_null($obj)){ $obj = &new stdClass(); } return $obj; } $obj = get_obj_ref(); $obj2 = get_obj_ref(); function get_obj_noref(){ static $obj = null; echo 'Ststic obj:',"<br />"; var_dump($obj); if(is_null($obj)){ $obj = new stdClass(); } return $obj; } $obj = get_obj_noref(); $obj2 = get_obj_noref();
정적으로 참조를 저장할 때 함수를 두 번 호출한 후에는 변수의 값이 저장되지 않으며, 위를 실행하면 프로그램은 Deprecated 오류를 보고합니다. 즉, 반환 참조 값 할당의 사용이 중단되었습니다.
2: 클래스 내 정적의 지연된 정적 바인딩
지연된 정적 바인딩은 호출된 클래스가 정적 상속의 컨텍스트에서 참조되도록 허용하는 것을 의미합니다. 지연된 바인딩은 다음을 의미합니다. static::은 더 이상 현재 메서드가 정의된 클래스가 아니라 실제로 실행되는 클래스입니다. 참고: (단, 이에 국한되지는 않음) 정적 메서드 호출에 사용할 수 있습니다.
간단한 정적 지연 바인딩 사용 외에도 순방향 호출도 있습니다. 즉, self::, parent::, static:: 및ward_static_call()을 사용합니다(이 함수는 호출만 가능함)
class A { public static function foo() { static::who(); } public static function who() { echo CLASS."\n"; } } class B extends A { public static function test() { A::foo(); parent::foo(); self::foo(); } public static function who() { echo CLASS."\n"; } } class C extends B { public static function who() { echo CLASS."\n"; } } C::test();
여기에서 얻은 결과는 A C C입니다. 분명히 parent::foo()를 호출할 때 런타임 호출 클래스가 계속 사용됩니다. .
또 다른 주의할 점은 다음과 같습니다. 명시적으로 선언된 정적 클래스만 하위 클래스와 하위 클래스입니다.
콘텐츠의 다음 부분은 이 블로그 게시물을 참조합니다. 링크를 열려면 클릭하세요: PHP 정적 상속
<span style="font-size:18px;">class A { protected static $var1 = null; protected static $var2 = null; public static function test(){ if(!static::$var2){ static::$var2 = static::$var1; } echo get_called_class().' '.static::$var2.' '; } } class B extends A { protected static $var1 = 'b'; } class C extends A { protected static $var1 = 'c'; } B::test(); C::test(); </span>
여기에서 얻은 결과는 b b입니다. 여기서 클래스 B는 먼저 test() 메서드를 호출했고 호출 후 $var2 변수에 값이 할당되었습니다. 그러나 클래스 C는 자체 $var2 변수를 정의하지 않았으며 $var2 변수 값이 이미 상위 클래스에 존재합니다. 클래스이므로 직접 사용할 수 있습니다. 클래스 B의 경우 $var2 변수를 에서 명시적으로 정의하면 결과가 달라집니다.
위 내용은 PHP의 static 키워드 사용법과 주의사항에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!