錯誤控制運算符

PHP 支持一個錯誤控制運算符:@。當將其放置在一個 PHP 表達式之前,該表達式可能產(chǎn)生的任何錯誤診斷都被抑制。

如果用 set_error_handler() 設(shè)定了自定義的錯誤處理函數(shù),即使診斷信息被抑制,也仍然會被調(diào)用,因此自定義錯誤處理函數(shù)應(yīng)該調(diào)用 error_reporting(),并驗證 @ 操作符是否按照如下方式使用:

<?php
function my_error_handler($err_no$err_msg$filename$linenum) {
    if (!(
error_reporting() & $err_no)) {
        return 
false// 靜默
    
}
    
// ...
}
?>

警告

PHP 8.0.0 之前,如果診斷被抑制,則傳遞給自定義錯誤處理函數(shù)的嚴重性值則始終為 0 。 PHP 8.0.0 起,情況則不再如此。

error_get_last() 返回數(shù)組中的 "message" 元素儲存了表達式產(chǎn)生的任意錯誤信息。 此函數(shù)的返回結(jié)果會隨著每次錯誤的發(fā)生而相應(yīng)變化,所以需要盡早檢查。

<?php
/* 故意文件錯誤 */
$my_file = @file ('non_existent_file') or
    die (
"Failed opening file: error was '" error_get_last()['message'] . "'");

// 這適用于所有表達式,而不僅僅是函數(shù):
$value = @$cache[$key];
// 如果索引 $key 不存在,則不會發(fā)出通知。

?>

注意: @ 運算符只對 表達式 有效。 對新手來說一個簡單的規(guī)則就是:如果能從某處獲得值,就能在它前面加上 @ 運算符。例如,可以把它放在變量,函數(shù)調(diào)用,某些語言構(gòu)造調(diào)用(例如 include )等等之前。 不能把它放在函數(shù)或類的定義之前,也不能用于條件結(jié)構(gòu)例如 ifforeach 等。

警告

PHP 8.0.0 之前,@ 運算符會禁用導(dǎo)致腳本停止運行的嚴重錯誤。 例如在調(diào)用一個不存在的函數(shù)前添加 @,由于函數(shù)不可用或者輸入錯誤, 將會導(dǎo)致腳本終止,而不會說明原因。