問題:在 C 中,有兩種方法可以定義具有預設參數的函數。首選哪種方法以及為什麼?
回應:
在 C 中,可以在函數宣告或定義中指定預設參數。雖然這兩種方法在語法上都有效,但首選方法是在聲明本身中指定預設參數。
這種偏好源自於當聲明和定義跨多個檔案分開時潛在的編譯問題。考慮以下示例:
lib.h(頭文件)
<code class="cpp">int Add(int a, int b);</code>
lib.cpp(源文件)
<code class="cpp">int Add(int a, int b = 3) { // Function implementation }</code>
test.cpp(測試檔)
<code class="cpp">#include "lib.h" int main() { Add(4); }</code>
編譯test.cpp 會出錯,因為lib.h 中的宣告沒有指定預設參數值。這是因為編譯器在編譯 test.cpp 時只看到聲明,而不是 lib.cpp 中的定義。
因此,建議始終在函數聲明中定義預設參數,如下所示:
lib.h
<code class="cpp">int Add(int a, int b = 3);</code>
透過在聲明中指定預設參數,即使函數定義不可用,編譯器也能知道它的存在,從而阻止編譯錯誤。
以上是為什麼在 C 語言中首選在函數宣告中指定預設參數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!