PHP는 오류 제어 연산자인 @를 지원합니다. PHP 표현식 앞에 배치하면 표현식에서 생성될 수 있는 모든 오류 메시지가 무시됩니다.
set_error_handler()를 사용하여 사용자 정의 오류 처리 함수를 설정하는 경우 여전히 호출되지만 이 오류 처리 함수는 error_reporting()을 호출할 수 있고 호출해야 하며 이 함수에는 @가 0을 반환합니다.
track_errors 기능이 활성화되면 표현식에 의해 생성된 모든 오류 메시지가 $php_errormsg 변수에 저장됩니다. 이 변수는 오류가 발생할 때마다 덮어쓰기가 되므로 사용을 원할 경우 최대한 빨리 확인하시기 바랍니다.
<?php /* Intentional file error */ $my_file = @file ('non_existent_file') or die ("Failed opening file: error was '$php_errormsg'"); // this works for any expression, not just functions: $value = @$cache[$key]; // will not issue a notice if the index $key doesn't exist. ?>
참고: @ 연산자는 표현식에만 유효합니다. 초보자를 위한 간단한 규칙은 다음과 같습니다. 어딘가에서 값을 얻을 수 있으면 값 앞에 @ 연산자를 추가하세요. 예를 들어 변수, 함수 및 호출, 상수 등을 포함할 수 있습니다. 함수나 클래스 정의 앞에 배치할 수 없으며 if 및 foreach와 같은 조건부 구조에서도 사용할 수 없습니다.
경고
[이메일 보호]��[이메일 보호]��[이메일 보호]�� 오류 메시지를 표시하지 않으려면 스크립트가 이유를 표시하지 않고 종료됩니다.