C 拾遺 斷言錯誤assert 函式用法總結

2021-06-22 12:54:48 字數 1861 閱讀 5953

**:

assert巨集的原型定義在中,其作用是如果它的條件返回錯誤,則終止程式執行,原型定義:

#include 

<

assert.h

>

void

assert(

intexpression );

assert的作用是現計算表示式 expression ,如果其值為假(即為0),那麼它先向stderr列印一條出錯資訊,然後通過呼叫 abort 來終止程式執行。請看下面的程式清單badptr.c:

#include 

<

stdio.h

>

#include

<

assert.h

>

#include

<

stdlib.h

>

intmain(

void

)

[root@localhost error_process]# gcc badptr.c 

[root@localhost error_process]# ./a.out 

a.out: badptr.c:14: main: assertion `fp' failed.

已放棄使用assert()的缺點是,頻繁的呼叫會極大的影響程式的效能,增加額外的開銷。在除錯結束後,可以通過在包含#include 的語句之前插入 #define ndebug 來禁用assert呼叫,示例**如下:

#include 

<

stdio.h

>

#define

ndebug

#include

<

assert.h

>

用法總結與注意事項:

1)在函式開始處檢驗傳入引數的合法性如:

int

resetbuffersize(

intnnewsize)

2)每個assert只檢驗乙個條件,因為同時檢驗多個條件時,如果斷言失敗,無法直觀的判斷是哪個條件失敗,如:

不好:

assert(noffset

>=0&&

noffset

+nsize

<=

m_ninfomationsize);

好:

assert(noffset 

>=0);

assert(noffset

+nsize

<=

m_ninfomationsize);

3)不能使用改變環境的語句,因為assert只在debug個生效,如果這麼做,會使用程式在真正執行時遇到問題,如:

錯誤:

assert(i

++<

100);

這是因為如果出錯,比如在執行之前i=100,那麼這條語句就不會執行,那麼i++這條命令就沒有執行。

正確:

assert(i 

<

100);

i++;

4)assert和後面的語句應空一行,以形成邏輯和視覺上的一致感。

5)有的地方,assert不能代替條件過濾。assert是用來避免顯而易見的錯誤的,而不是處理異常的。錯誤和異常是不一樣的,錯誤是不應該出現的,異常是不可避免的。c語言異常可以通過條件判斷來處理,其它語言有各自的異常處理機制。

乙個非常簡單的使用assert的規律就是,在方法或者函式的最開始使用,如果在方法的中間使用則需要慎重考慮是否是應該的。方法的最開始還沒開始乙個功能過程,在乙個功能過程執行中出現的問題幾乎都是異常。

C 拾遺 函式過載

c 拾遺 函式過載 關於作用域,需要指出幾點事實 用大括號 括起來的區域處於同一作用域,常見的有函式體 for if語句等。同一作用域內不可出現同名的變數,若是函式同名,那就是函式過載問題。不同作用域內同名與否,沒影響。所有的函式之外的區域就是全域性作用域。首先需要指出,同一作用域中的函式才會出現過...

C 拾遺(二 函式)

1.引數陣列。c 的特色,允許函式引數的最後指定乙個引數陣列,可以使用個數不定的引數呼叫,用params關鍵字定義 static double sumvals params double vals return sum 呼叫sumvals 1,2,3 2.值引數和引用引數。引用引數使用關鍵字ref指...

函式呼叫拾遺

通常構成函式主題的js 在定義之時是不會被執行的,只有在呼叫函式是才會被執行 有4種方式可以呼叫js函式 定義函式 factorial function factorial var probability factorial 5 以函式形式呼叫的函式通常不適用this關鍵字 方法呼叫和函式呼叫區別在...