最負整數的重載解析中的歧義
在C 中,函數重載允許多個函數具有相同的名稱但不同的參數類型。但是,在解析重載函數呼叫時,如果編譯器無法確定要呼叫的最合適的函數,則可能會出現歧義。
請考慮以下程式碼,示範用於顯示整數和無符號整數值的函數重載:
<code class="cpp">void display(int a) { cout << "int" << endl; } void display(unsigned a) { cout << "unsigned" << endl; }
根據我們的理解,任何在int指定範圍內的整數值都應該呼叫display(int),而超出這個範圍的值會導致歧義。但是,當嘗試傳遞最負的 int 值 (-2147483648) 進行顯示時,編譯器會引發錯誤:
call of overloaded display(long int) is ambiguous
這種令人驚訝的行為源於 C 中缺少負整數文字。 C 標準中定義的整數文字不包含「-」字元。相反,當遇到“-”後跟數字時,編譯器會將其視為應用於正整數文字的一元否定運算符。
在我們的例子中,「-2147483648」被解釋為「-1 *」 2147483648'。由於'2147483648'超出了int的範圍,因此它被提升為long int。這種類型提升會導致歧義,因為現在 display(int) 和 display(long int) 都是函式呼叫的可行候選者。
為了避免此類歧義,建議使用 std::numeric_limits 類別來以可移植的方式檢索不同資料類型的最小值或最大值:
<code class="cpp">std::cout << std::numeric_limits<int>::min() << endl;</code>
以上是為什麼將最大負整數傳遞給重載函數會導致 C 中的歧義?的詳細內容。更多資訊請關注PHP中文網其他相關文章!