>  기사  >  백엔드 개발  >  PHP에서 매직 메소드를 인식하는 방법

PHP에서 매직 메소드를 인식하는 방법

coldplay.xixi
coldplay.xixi원래의
2020-09-29 13:11:142089검색

PHP에서는 "__", 즉 두 개의 밑줄로 시작하는 모든 클래스 메서드가 매직 메서드로 예약되어 있습니다. PHP의 매직 메서드에는 "__construct()", "__destruct()", "__call()", " __callStatic( )" 등.

PHP에서 매직 메소드를 인식하는 방법

마법 메서드는 다음과 같습니다.

1, __get, __set

이 두 메서드는 클래스와 해당 상위 클래스에 선언되지 않은 속성을 위해 설계되었습니다.

__get( $property ) 호출 시 정의되지 않은 속성인 경우 이 메서드가 트리거됩니다. 전달된 매개 변수는 액세스되는 속성의 이름입니다.

__set( $property, $value ) 정의되지 않은 속성에 값을 할당하면 이 메서드가 트리거됩니다. 매개변수는 설정된 속성 이름과 값입니다.

여기 선언에는 객체 호출 시 액세스 제어가 보호되고 비공개인 속성(즉, 액세스 권한이 없는 속성)이 포함되지 않습니다.

2, __isset, __unset

__isset( $property ) 정의되지 않은 속성에 대해 isset() 함수가 호출될 때 이 메서드가 호출됩니다.

__unset( $property ) 정의되지 않은 속성에 대해 unset()이 호출될 때 이 메서드는 함수 사용 시 호출

여기에서 선언되지 않은 속성에는 객체를 사용하여 호출할 때 액세스 제어가 보호되고 비공개인 속성(즉, 액세스 권한이 없는 속성)이 포함됩니다.

3. __call

__call( $method, $arg_array ) 이 메소드는 정의되지 않은 메소드를 호출할 때 호출됩니다.

여기서 정의되지 않은 메소드에는 액세스 권한이 없는 메소드가 포함되어 있습니다. 해당 메소드가 존재하지 않으면 상위 클래스로 이동하여 찾으십시오. 상위 클래스에 없으면 이 클래스의 __call() 메서드를 호출하고, 이 클래스에 __call() 메서드가 없으면 상위 클래스의 __call() 메서드로 이동합니다.

4. __autoload

__autoload 아직 정의되지 않은 클래스를 사용하려고 할 때 자동으로 호출되는 함수입니다. 이 함수를 호출하면 스크립팅 엔진은 PHP가 오류로 인해 실패하기 전에 필요한 클래스를 로드할 수 있는 마지막 기회를 갖게 됩니다.

전역 자동 로딩 클래스를 정의하려면 spl_autoload_register() 메서드를 사용하여 처리 클래스를 PHP 표준 라이브러리에 등록해야 합니다.

코드는 다음과 같습니다.

<?php   
class Loader   
{   
static function autoload_class($class_name)   
{   
//寻找正确的$class_name类,并引入,没有则抛出异常   
}   
}   
/**
*   设置对象的自动载入
*   spl_autoload_register — Register given function as __autoload() implementation
*/   
spl_autoload_register(array(&#39;Loader&#39;, &#39;autoload_class&#39;));   
$a = new Test();//Test没用require就实例化,实现自动加载,很多框架就用这种方法自动加载类   
?>

참고: __autoload 함수에서 예외가 발생합니다. 포착할 수 없습니다. 명령문 블록은 치명적인 오류를 포착하고 발생시키므로 포착은 함수 자체에서 수행되어야 합니다.

5, __construct, __destruct

__construct 생성자 메서드인 이 메서드는 객체가 생성될 때 호출됩니다. PHP4와 비교하여 이 메서드를 사용하는 장점은 클래스 이름에 관계없이 생성자 메서드가 고유한 이름을 가질 수 있다는 것입니다. 뭐. 그래서 클래스 이름을 변경할 때 생성자 메서드

__destruct 소멸자 메서드의 이름을 변경할 필요가 없습니다. PHP는 객체가 파괴되기 전에 이 메서드를 호출합니다. , 메모리에서 지워지기 전). 기본적으로 PHP는 객체 속성이 차지하는 메모리만 해제하고 객체 관련 리소스를 파괴합니다. 소멸자를 사용하면 객체를 사용한 후 임의의 코드를 실행하여 메모리를 지울 수 있습니다. PHP가 스크립트가 더 이상 객체와 연관되어 있지 않다고 결정하면 소멸자가 호출됩니다.

함수의 네임스페이스에서는 함수가 반환될 때 이런 일이 발생합니다.

전역 변수의 경우 이는 스크립트 끝에서 발생합니다.

객체를 명시적으로 삭제하려면 객체를 가리키는 변수에 다른 값을 할당할 수 있습니다. 일반적으로 변수를 NULL로 할당하거나 unset을 호출합니다.

6, __clone

PHP5의 객체 할당은 참조 할당을 사용합니다. , 객체를 복사하려면 clone 메소드를 사용해야 합니다. 이 메소드가 호출되면 객체는 자동으로 __clone 매직 메소드를 호출합니다. 객체를 복사할 때 일부 초기화 작업을 수행해야 하는 경우 이를 구현할 수 있습니다. __clone 메소드에서.

7. __toString

__toString 메소드는 객체를 인쇄하기 위해 echo를 사용할 때와 같이 객체를 문자열로 변환할 때 자동으로 호출됩니다.

클래스가 이 메소드를 구현하지 않으면 에코를 통해 객체를 인쇄할 수 없습니다. 그렇지 않으면 다음과 같이 표시됩니다. Catchable fatal error: 클래스 테스트의 객체를 문자열로 변환할 수 없습니다.

이 메소드는 문자열을 반환해야 합니다.

PHP 5.2.0 이전에는 __toString 메서드가 echo() 또는 print()와 함께 사용될 때만 효과가 있었습니다. PHP 5.2.0 이후에는 모든 문자열 환경(예: %s 수정자를 사용하여 printf()를 통해)에서 적용할 수 있지만 문자열이 아닌 환경(예: %d 수정자 사용)에서는 사용할 수 없습니다. PHP 5.2.0부터 __toString 메소드를 정의하지 않은 객체가 문자열로 변환되면 E_RECOVERABLE_ERROR 오류가 보고됩니다.

8, __sleep, __wakeup

__sleep 직렬화할 때

__wakeup을 사용하세요. 역직렬화할 때

serialize()를 호출하여 클래스에 매직 이름이 __sleep인 함수가 있는지 확인하세요. 그렇다면 함수는 직렬화 전에 실행됩니다. 개체를 지우고 직렬화해야 하는 개체의 모든 변수 이름이 포함된 배열을 반환해야 합니다.

__sleep을 사용하는 목적은 개체에 있을 수 있는 모든 데이터베이스 연결을 닫거나, 보류 중인 데이터를 제출하거나, 유사한 정리 작업을 수행하는 것입니다. 또한 이 기능은 완전히 저장할 필요가 없는 매우 큰 개체가 있는 경우에도 유용합니다.

반대로, unserialize()는 마법 이름이 __wakeup인 함수가 있는지 확인합니다. 이 함수는 객체에 있을 수 있는 모든 리소스(있는 경우)를 재구성할 수 있습니다.

__wakeup을 사용하는 목적은 직렬화 중에 손실되었을 수 있는 데이터베이스 연결을 다시 설정하고 기타 재초기화 작업을 처리하는 것입니다.

9.__set_state

var_export()가 호출되면 이 정적 메서드가 호출됩니다(PHP 5.1.0부터 유효).

이 메소드의 유일한 매개변수는 배열('속성' => 값, ...) 형식으로 정렬된 클래스 속성을 포함하는 배열입니다.

10. __invoke

함수를 호출하여 객체를 호출하려고 하면 __invoke 메서드가 자동으로 호출됩니다.

PHP5.3.0 이상이 유효합니다.

11.__callStatic

__call() 매직 메소드와 유사하게 작동하며, __callStatic()은 정적 메소드 호출을 처리하는 것입니다.

PHP5.3.0 이상이 유효합니다.

PHP __callStatic() 메서드의 정의가 강화되었습니다. 이 메서드는 공개되어야 하며 정적으로 선언되어야 합니다. 마찬가지로 __call() 매직 메서드는 public으로 정의되어야 하며 다른 모든 매직 메서드는 public으로 정의되어야 합니다.

프로그래밍에 대해 더 자세히 알고 싶다면 php training 칼럼에 주목하세요!

위 내용은 PHP에서 매직 메소드를 인식하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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