首頁  >  文章  >  後端開發  >  為什麼將最大負整數傳遞給重載函數會導致 C 中的歧義?

為什麼將最大負整數傳遞給重載函數會導致 C 中的歧義?

Linda Hamilton
Linda Hamilton原創
2024-11-04 12:51:29625瀏覽

Why Does Passing the Most Negative Integer to an Overloaded Function Cause Ambiguity in C  ?

最負整數的重載解析中的歧義

在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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn