在 C 中省略 Return 語句
在 C 中,習慣上用 return 語句終止非 void 函數。然而,在與 Strawberry Perl 一起分發的 g 的特定 Windows 版本中觀察到了奇怪的現象。此版本允許在傳回非 void 值的函數中省略 return 語句,導致意外行為。
考慮以下成員函數:
struct boundTag Box::getBound(int side) { struct boundTag retBoundTag; retBoundTag.box = this; switch (side) { // set retBoundTag.bound based on value of "side" } }
此函數旨在傳回表示綁定標籤的結構。然而,開發人員無意中省略了 return 語句:
// ... code from above }
測試此函數時,儘管缺少 return 語句,開發人員仍收到了有效的輸出。即使刪除 return 語句後,程式碼編譯時也不會出現任何警告。
根本問題是在非 void 函式中省略 return 語句會呼叫未定義的行為。 ISO C -98 標準明確指出,從非 void 函數末端流出相當於傳回無值,導致未定義的行為。
// ... code from above // Undefined behavior }
在這種情況下, g 可能會傳回 a垃圾值,因為編譯器無法確定預期的回傳值。在程式碼中使用此傳回值是危險的,可能會導致不可預測的結果。
雖然預設 g 可能不會發出警告,但在編譯期間使用 -Wall 選項會強制編譯器對這些情況發出警告。此選項將突出顯示缺少的 return 語句並有助於防止此類未定義的行為。
因此,即使不立即使用回傳值,也必須始終在非 void 函數中包含 return 語句。這種做法確保程式碼符合 C 標準並避免任何潛在的未定義行為。
以上是為什麼在非 Void C 函數中省略 Return 語句有時會起作用(以及為什麼不應該起作用)?的詳細內容。更多資訊請關注PHP中文網其他相關文章!