溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP中斷言函數(shù)的用法

發(fā)布時間:2021-06-23 10:09:17 來源:億速云 閱讀:132 作者:chen 欄目:編程語言

本篇內容介紹了“PHP中斷言函數(shù)的用法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

原來一直以為斷言相關的函數(shù)是 PHPUnit 這些單元測試組件提供的,在閱讀手冊后才發(fā)現(xiàn),這個 assert() 斷言函數(shù)是 PHP 本身就自帶的一個函數(shù)。也就是說,我們在代碼中進行簡單的測試的時候是不需要完全引入整個單元測試組件的。

assert() 斷言函數(shù)

assert(1==1);

assert(1==2);
// assert.exception = 0 時,Warning: assert(): assert(1 == 2)
// assert.exception = 1 時,F(xiàn)atal error: Uncaught AssertionError: 驗證不通過

很明顯,第二段代碼無法通過斷言驗證。這時,PHP 就會返回一個警告或者異常錯誤。為什么有可能是兩種錯誤形式呢?當我們設置 php.ini 中的 assert.exception 為 off 或者 0 時,也就是關閉這個參數(shù)的能力時,程序就會以 PHP5 的形式依然返回一個警告,就像上面代碼中的注釋一樣。同時,通過 try...catch 也無法進行異常的捕獲了。這個參數(shù)其實就是控制是否以正宗的異常對象進行拋出。如果保持這個參數(shù)為默認情況也就是設置為 on 或者 1 的話,就會直接拋出異常,程序中止。

從上述代碼可以看出,斷言的第一個參數(shù)是一個表達式,而且是需要一個返回 bool 類型對象的表達式。如果我們傳遞的是一個字符串或者一個數(shù)字呢?

// 設置 assert.exception = 0 進行多條測試

assert(" ");
// Deprecated: assert(): Calling assert() with a string argument is deprecated
// Warning: assert(): Assertion " " failed

assert("1");
// Deprecated: assert(): Calling assert() with a string argument is deprecated

assert(0);
// Warning: assert(): assert(0) failed

assert(1);

assert("1==2");
// Deprecated: assert(): Calling assert() with a string argument is deprecated
// Warning: assert(): Assertion "1==2" failed

很明顯第一個參數(shù)的表達式會進行類型強制轉換,但是字符串類型會多出一個過時提醒,表明給 assert() 函數(shù)傳遞字符串類型的表達式類型已經(jīng)過時了。當前的測試版本是 7.3 ,在將來可能就會直接報中止運行的錯誤或異常了。主要問題在于,如果傳遞的字符串本身也是一個表達式的話,會以這個表達式的內容為基礎進行判斷,這樣很容易產生歧義,就像最后一段代碼一樣。當然,已經(jīng)過時的使用方式還是不推薦的,這里僅是做一個了解即可。

接下來我們看一下 assert() 函數(shù)的其他參數(shù),它的第二個參數(shù)是兩種類型,要么給一個字符串用來定義錯誤的信息,要么給一個 異常類 用于拋出異常。

assert(1==1, "驗證不通過");

assert(1==2, "驗證不通過");
// Warning: assert(): 驗證不通過 failed

如果直接給的一個字符串,那么在警告的提示信息中,顯示的就是我們定義的這個錯誤信息的內容。這個非常好理解。

// 注意 assert.exception 設置不同的區(qū)別

assert(1==1,  new Exception("驗證不通過"));

assert(1==2,  new Exception("驗證不通過"));
// assert.exception = 1 時,F(xiàn)atal error: Uncaught Exception: 驗證不通過
// assert.exception = 0 時,Warning: assert(): Exception: 驗證不通過

當然,我們也可以給一個 異常類 讓斷言拋出一個異常。在默認情況下,這個異常的拋出將中止程序的運行。也就是一個正常的異常拋出流程,我們可以使用 try...catch 進行異常的捕獲。

try{
    assert(1==2,  new Exception("驗證不通過"));
}catch(Exception $e){
    echo "驗證失??!:", $e->getMessage(), PHP_EOL;
}
// 驗證失敗!:驗證不通過

另外還有一個參數(shù)會對斷言的整體運行產生影響,那就是 php.ini 中的 zend.assertions 參數(shù)。它包含三個值:

  • 1,生成并執(zhí)行代碼,一般在測試環(huán)境使用

  • 0,生成代碼但是在運行時會路過

  • -1,不生成代碼,一般在正式環(huán)境使用

這個參數(shù)大家可以自行配置測試,默認的 php.ini 中它的默認值是 1 ,也就是正常的執(zhí)行 assert() 函數(shù)。

assert_options() 及相對應的 php.ini 中的參數(shù)配置

PHP 中的斷言功能還為我們提供了一個 assert_options() 函數(shù),用于方便地設置和獲取一些和斷言能力有關的參數(shù)配置。它能夠設置的斷言標志包括:

標志 | INI設置 | 默認值 | 描述

  • | :-: | :-: | -:

ASSERT_ACTIVE | assert.active | 1 | 啟用 assert() 斷言 ASSERT_WARNING | assert.warning | 1 | 為每個失敗的斷言產生一個 PHP 警告(warning) ASSERT_BAIL | assert.bail | 0 | 在斷言失敗時中止執(zhí)行 ASSERT_QUIET_EVAL | assert.quiet_eval | 0 | 在斷言表達式求值時禁用 error_reporting ASSERT_CALLBACK | assert.callback | (NULL) | 斷言失敗時調用回調函數(shù)

這些參數(shù)的含義都非常好理解,大家可以自己測試一下。我們就來看一下最后一個 ASSERT_CALLBACK 的作用。其實它的說明也非常清楚,就是斷言失敗的情況下就進入到這個選項定義的回調函數(shù)中。

assert_options(ASSERT_ACTIVE, 1);
assert_options(ASSERT_WARNING, 1);
assert_options(ASSERT_BAIL, 1);

assert_options(ASSERT_CALLBACK, function($params){
    echo "====faild====", PHP_EOL;
    var_dump($params);
    echo "====faild====", PHP_EOL;
});

assert(1!=1);
// ====faild====
// string(105) ".../source/一起學習PHP中斷言函數(shù)的使用.php"
// ====faild====

當斷言失敗的時候,我們就進入了回調函數(shù)中,在回調函數(shù)直接簡單的打印了傳給回調函數(shù)的參數(shù)內容??梢钥闯觯@個回調函數(shù)里面?zhèn)鬟f過來的是無法通過斷言的文件信息。

總結

學習掌握一下斷言函數(shù)的使用及配置,可以為我們將來學習 PHPUnit 單元測試打下基礎,當然,本身這個能力的東西就不是很多,大家記住就好啦!

測試代碼:
https://github.com/zhangyue0503/dev-blog/blob/master/php/202005/source/%E4%B8%80%E8%B5%B7%E5%AD%A6%E4%B9%A0PHP%E4%B8%AD%E6%96%AD%E8%A8%80%E5%87%BD%E6%95%B0%E7%9A%84%E4%BD%BF%E7%94%A8.php

“PHP中斷言函數(shù)的用法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注億速云網(wǎng)站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

php
AI