Latest web development tutorials

PHP 7 異常

PHP 7 新特性 PHP 7新特性

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

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


assert() 配置

配置項 默認值 可選值
zend.assertions 1
  • 1 -生成和執行代碼(開發模式)

  • 0 -生成代碼,但在執行時跳過它

  • -1 -不生成代碼(生產環境)

assert.exception 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

PHP 7 新特性 PHP 7新特性