PHP 7 異常

PHP 7 異常用於向下相容及增強舊的assert()函數。它能在生產環境中實現零成本的斷言,並且提供拋出自定義異常及錯誤的能力。

舊版的API出於相容目的將繼續被維護,assert()現在是一個語言結構,它允許第一個參數是一個表達式,而不僅僅是一個待計算的string或一個待測試的boolean。


assert() 設定

##可選值zend.assertions1#assert.exception#參數
設定項預設值
  • #1 - 產生與執行程式碼(開發模式)

  • 0 - 產生程式碼,但在執行時跳過它

  • ##-1

    - 不產生程式碼(生產環境)

#0
  • 1

    - 斷言失敗時拋出,可以拋出異常對象,如果沒有提供異常,則拋出AssertionError 物件實例。

  • 0

    - 使用或產生Throwable, 只是基於物件產生的警告而不是拋出物件(與PHP 5 相容)

    #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!';
?>

以上程式執行輸出結果為:

Hi!
將zend.assertions 設為1,assert.exception 設定為1:

實例
<?php
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