巨集定義中的do...while(0)如果你是c++程式設計師,我有理由相信你用過,或者接觸過,至少聽說過mfc, 在mfc的afx.h檔案裡面, 你會發現很多巨集定義都是用了do...while(0)或do...while(false), 比如說:
#define afxassume(cond) do while(0)
粗看我們就會覺得很奇怪,既然迴圈裡面只執行了一次,我要這個看似多餘的do...while(0)有什麼意義呢?
當然有!
為了看起來更清晰,這裡用乙個簡單點的巨集來演示:
#define safe_delete(p) do while(0)
假設這裡去掉do...while(0),
#define safe_delete(p) delete p; p = null;
那麼以下**:
if(null != p) safe_delete(p)
else ...do sth...
就有兩個問題,
1) 因為if分支後有兩個語句,else分支沒有對應的if,編譯失敗
2) 假設沒有else, safe_delete中的第二個語句無論if測試是否通過,會永遠執行。
你可能發現,為了避免這兩個問題,我不一定要用這個令人費解的do...while, 我直接用{}括起來就可以了
#define safe_delete(p)
的確,這樣的話上面的問題是不存在了,但是我想對於c++程式設計師來講,在每個語句後面加分號是一種約定俗成的習慣,這樣的話,以下**:
if(null != p) safe_delete(p);
else ...do sth...
其else分支就無法通過編譯了(原因同上),所以採用do...while(0)是做好的選擇了。
也許你會說,我們**的習慣是在每個判斷後面加上{}, 就不會有這種問題了,也就不需要do...while了,如:
if(...)
else
誠然,這是乙個好的,應該提倡的程式設計習慣,但一般這樣的巨集都是作為library的一部分出現的,而對於乙個library的作者,他所要做的就是讓其庫具有通用性,強壯性,因此他不能有任何對庫的使用者的假設,如其編碼規範,技術水平等。
C語言巨集定義中使用do while 0 的理由
眾所周知,c語言支援巨集定義,並且功能強大。舉個例子 include define swap a,b int main 不過,巨集定義雖然強大,但是有時候卻難以駕馭它。上述巨集定義 define swap a,b 乍一看沒什麼問題,裡面使用了變數t,如果巨集定義外面也有變數叫t怎麼辦?這個不用擔心,...
關於巨集中使用do while 0 的作用
關於do while 0 大家肯定不會陌生,就是do 裡面的迴圈體執行一次,且僅執行一次。那這樣和普通的語句有什麼區別呢?在巨集中,這樣做是為了保證巨集的正確執行 行為一致 就跟if n 0 大家會寫成if 0 n 一樣。一下是乙個例子,便於理解。include stdio.h define div...
do while 0 在巨集定義中的作用
如果你是一名c程式設計師,你肯定熟悉巨集,它們非常的強大,如果正確使用可以讓你的工作事半功倍。然後,如果你在定義巨集時,很隨意沒有認真檢查,那麼它們可能使得你發狂,浪費n多時間。在很多c程式中,你可能看到許多看起來不是那麼直接的較為特殊的巨集定義。下面就是乙個例子 1 define set taks...