PHP 7 異常
PHP 7 異常用於向下相容及增強舊的assert()函數。它能在生產環境中實現零成本的斷言,並且提供拋出自定義異常及錯誤的能力。
老版本的API出於相容目的將繼續被維護,assert()現在是一個語言結構,它允許第一個參數是一個運算式,而不僅僅是一個待計算的 string或一個待測試的boolean。
assert() 配置
配置項 | 默認值 | 可選值 |
---|---|---|
zend.assertions | 1 |
|
assert.exception | 0 |
|
參數
- assertion
-
斷言。在 PHP 5 中,是一個用於執行的字串或者用於測試的布爾值。在 PHP 7 中,可以是一個返回任何值的運算式, 它將被執行結果用於指明斷言是否成功。
- description
-
如果
assertion
失敗了,選項 description 將會包括在失敗資訊裏。 - exception
-
在 PHP 7 中,第二個參數可以是一個 Throwable 對象,而不是一個字串,如果斷言失敗且啟用了 assert.exception 該對象將被拋出。
實例
將 zend.assertions 設置為 0:
實例
<?php
ini_set('zend.assertions', 0);
assert(true == false);
echo 'Hi!';
?>
ini_set('zend.assertions', 0);
assert(true == false);
echo 'Hi!';
?>
以上程式執行輸出結果為:
Hi!
將 zend.assertions 設置為 1,assert.exception 設置為 1:
實例
<?php
ini_set('zend.assertions', 1);
ini_set('assert.exception', 1);
assert(true == false);
echo 'Hi!';
?>
ini_set('zend.assertions', 1);
ini_set('assert.exception', 1);
assert(true == false);
echo 'Hi!';
?>
以上程式執行輸出結果為:
Fatal error: Uncaught AssertionError: assert(true == false) in -:2 Stack trace: #0 -(2): assert(false, 'assert(true == ...') #1 {main} thrown in - on line 2