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

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

Linda Hamilton
發布: 2024-11-04 12:51:29
原創
691 人瀏覽過

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

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板