如果你是
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 0
有時程式中重複出現某幾條語句,為了保證程式dry don t repeat yourself 需要將這幾條語句合併為一條語句.在c 中可以選擇用 inline,c語言沒有這個特性,但是可以用巨集實現.正確答案是用dowhile 0 實現,下面推理下為什麼這種方法最好吧.思路一 直接寫在一起 比如要將...
巨集定義中的do while 0
如果你是c 程式設計師,我有理由相信你用過,或者接觸過,至少聽說過mfc,在mfc的afx.h檔案裡面,你會發現很多巨集定義都是用了do.while 0 或do.while false 比如說 define afxassume cond do while 0 粗看我們就會覺得很奇怪,既然迴圈裡面只執...
巨集定義中的do while 0
我們都知道do while迴圈,但是在巨集定義中常常會出現dowhile 0 的用法,這樣的迴圈不是只執行一次嗎?不用do while也可以實現相同的功能呀,那麼為什麼要使用dowhile 0 呢?我們先來分析幾個例子 define fun x func1 x func2 x if true fun...