偶爾會有讀者問:改bug有什么技巧?
有經(jīng)驗的工程師都知道,隨著軟件版本的迭代,或者需求不斷變更,我們的代碼就會變得越來越“臃腫”。
在編碼的過程中,如果沒有注重一些細(xì)節(jié),你的代碼就可能存在許多隱藏的Bug。
那么,我們?nèi)绾握页鲞@些隱藏的Bug呢?
今天就說其中的一點:Assert斷言。
關(guān)于Assert斷言
什么是Assert斷言?
編寫代碼時,我們總是會做出一些假設(shè),斷言就是用于在代碼中捕捉這些假設(shè),可以將斷言看作是異常處理的一種高級形式。
斷言表示為一些布爾表達(dá)式,程序員相信在程序中的某個特定點該表達(dá)式值為真。
可以在任何時候啟用和禁用斷言驗證,因此可以在測試時啟用斷言,而在部署時禁用斷言。
同樣,程序投入運行后,最終用戶在遇到問題時可以重新啟用斷言。 ---來自百度百科
這里的概念,可能不好理解,簡單舉一個例子來說明吧。
有這么一個數(shù)組和函數(shù):
int Array[5] = {0xA1, 0xB2, 0xC3, 0xD4, 0xE5}; int Fun(char i) { return Array[i]; }如果我們函數(shù)中不加Assert斷言語句,你覺得直接調(diào)用會這個函數(shù)會有風(fēng)險嗎? 假如這么調(diào)用:
int a; a = Fun(8);很明顯,就這么調(diào)用,會出錯,且我們不容易發(fā)現(xiàn)錯誤在哪里。
但是,假如添加有Assert斷言語句,錯誤就能一下找出來。
Assert斷言實際應(yīng)用
其實,Assert斷言在很多標(biāo)準(zhǔn)的代碼中,基本都有。我們還是拿STM32的代碼來說明吧。
不管是STM32標(biāo)準(zhǔn)外設(shè)庫、還是HAL、LL庫源代碼里面都有Assert斷言機制。
不知道大家有沒有注意過assert_param函數(shù)?
1.拿STM32最常見的GPIO初始化函數(shù)為例 A.標(biāo)準(zhǔn)外設(shè)庫GPIO初始化:
B.HAL庫GPIO初始化: ?
相信大家都看到過STM32庫中的參數(shù)斷言語句,他的作用就是用于檢查函數(shù)傳入?yún)?shù)是否正確。
2.STM32參數(shù)斷言使能
STM32的assert_param參數(shù)斷言函數(shù)是沒有使能的,如下:
#define assert_param(expr) ((void)0)
也就是assert_param不起作用。
如果需要使用,就需要對其使能才行。
A.標(biāo)準(zhǔn)外設(shè)庫

B.HAL庫
道理一樣,使能ASSERT,可以手動:
#define USE_FULL_ASSERT 1U也可以通過STM32CubeMX配置:

3.代碼大小
添加Assert斷言之后,代碼量肯定要增加,比如: 不使能assert_param代碼量:
Code=5350 RO-data=360 RW-data=16 ZI-data=1152
使能assert_param:
Code=8300 RO-data=362 RW-data=16 ZI-data=1152
4.斷言失敗處理
斷言失敗,可根據(jù)實際項目需求,做出一定處理。比如:打印錯誤信息,存儲錯誤日志等。 本文就講到這里,具體如何應(yīng)用實際項目中,還需要大家進(jìn)一步深入理解其中精髓。
審核編輯:湯梓紅
-
標(biāo)準(zhǔn)庫
+關(guān)注
關(guān)注
0文章
31瀏覽量
7672 -
ASSERT
+關(guān)注
關(guān)注
0文章
17瀏覽量
7445 -
HAL
+關(guān)注
關(guān)注
2文章
72瀏覽量
12986
原文標(biāo)題:HAL和標(biāo)準(zhǔn)庫的Assert斷言機制
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
解析C語言斷言函數(shù)的使用

請問HAL函數(shù)對Handle有效性的檢查為什么不是用assert_param斷言?
HAL庫和標(biāo)準(zhǔn)庫的原理區(qū)別
標(biāo)準(zhǔn)庫和HAL庫有啥區(qū)別
何為斷言?斷言該怎么使用呢
STM32標(biāo)準(zhǔn)庫改為HAL庫的程序?qū)崿F(xiàn)
STM32Cube HAL庫中斷處理機制 以及回調(diào)函數(shù)實現(xiàn)原理
仿標(biāo)準(zhǔn)庫,對HAL庫的補充代碼

STM32函數(shù)庫Assert斷言機制

評論