Hata Denetim İşleçleri

PHP tek bir hata denetim işlecini destekler: kuyruklu a imi (@). PHP'de bir deyimin başına getirildiğinde, bu deyimin üreteceği olası hata iletileri engellenir.

set_error_handler() ile özel bir hata işleyici işlevi ayarlanırsa, tanılama bastırılmış olsa bile işlev çağrılır.

Uyarı

PHP 8.0.0'dan önce, özel hata işleyicisinden çağrılan error_reporting() işlevi, hata @ işleci ile bastırılmış olsa bile daima 0 döndürürdü. PHP 8.0.0 ve sonrasında E_ERROR | E_CORE_ERROR | E_COMPILE_ERROR | E_USER_ERROR | E_RECOVERABLE_ERROR | E_PARSE bitsel ifadesinin değeri dönmektedir.

İfade tarafından üretilenhata iletisi, get_error_last() işlevinden dönen dizinin "message" elemanında bulunur. Bu işlevin sonucu her hatada değişir, bu bakımdan sonuca yeterince kısa sürede bakmak gerekir.

<?php
/* Kasıtlı dosya hatası */
$dosyam = @file ('var_olmayan_dosya') or
die (
"Dosya açılamadı: hata '" . get_error_last()['message'] . "'");

// İfadelerle çalışır ama işlevlerle çalışmaz:
$değer = @$cache[$key];
// $key indisi mevcut değilse bir uyarı çıktılanır.

?>

Bilginize: Kuyruklu a işleci sadece ifadelerin başında kullanıldığında çalışır. Kısaca: Bir değer elde edilebilen herşeyin başına @ getirilebilir. Örneğin, değişkenlerin işlev veya include çağrılarının, sabitlerin ve benzerlerinin başına @ getirilebilir. Ama işlev veya sınıf tanımlarının veya if ve foreach gibi denetim yapılarının başına @ konamaz.

Uyarı

PHP 8.0.0 öncesinde, @ hata denetim işleci ile betiğin çalışmasını sonlandıracak önemli hataların raporlanmasını iptal etmek mümkündü. Bu bakımdan, işleç örneğin bir işlevden kaynaklanabilecek hataları bastırmak için kullanılıyorsa, işlev tanımında yapılan yazım hataları nedeniyle veya işlevin yokluğu halinde, ne olup bittiği anlaşılamadan betik sonlanabiliyordu.