使用Const 參數重載函數:為什麼它不能完成
在C 中,重載一個函數允許多個具有相同名稱的函數,但是不同的參數列表可以在一個類別中共存。然而,我們不能僅根據非指標、非引用參數的常數來重載函數。
考慮以下程式碼範例:
#include <iostream> using std::cout; class Test { public: Test() {} int foo(const int) const; // const function int foo(int); // non-const function }; int main() { Test obj; Test const obj1; int variable = 0; do { obj.foo(3); // Call the const function obj.foo(variable); // Attempt to call the non-const function variable++; usleep(2000000); } while (1); } int Test::foo(int a) { cout << "NON CONST" << std::endl; a++; return a; } int Test::foo(const int a) const { cout << "CONST" << std::endl; return a; }
如程式碼所示,我們嘗試根據參數的constness 重載foo 方法:接受const 參數的const 版本和接受非const 參數的非const版本。但是,此程式碼將導致編譯錯誤,指出該函數無法重載。
出現此錯誤是因為 C 不允許僅基於非指標、非參考型別的常數性進行重載。原因是當傳遞值參數時,實際參數會複製到被呼叫函數內的暫存變數。這個副本與原始參數不同,它的常數性不會影響原始參數的常數性。
因此,在上面的範例中,當呼叫 obj.foo(3) 時,會產生文字的臨時副本3 被創建,並將其傳遞給 const 函數。類似地,當呼叫 obj.foo(variable) 時,會建立變數的暫存副本並將其傳遞給非常量函數。編譯器無法僅根據參數的常數來區分這兩種情況。
總之,C 中不允許基於非指標、非引用型別的常數重載函數。這是因為值參數的常數不會影響函數內部參數的常數,並且編譯器無法僅根據參數類型區分兩者。
以上是為什麼不能只根據非指標、非參考參數的常數來重載 C 函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!