最令人煩惱的解析:解開C 11 中的歧義
當使用統一初始化器時,C 11 中的“最令人困擾的解析」歧義會出現,如以下程式碼片段所示:
#include
class Timer
{
public:
Timer() {}
};
int main()
{
auto dv = Timer(); // Ambiguity: Object or function call?
int time_keeper(Timer()); // Ambiguity: Pointer or call?
return 0;
}
理解第一個表達式(auto dv = Timer())
在第一個表達式中,auto 關鍵字意味著dv 的型別是從初始化器推斷出來的位於等號(=) 的右側。初始化程序是對不帶參數的 Timer 建構函數的調用,它會傳回一個 Timer 物件。因此,dv 是 Timer 類型的物件。
理解第二個表達式(int time_keeper(Timer()))
在第二個表達式中,出現歧義是因為編譯器無法確定Timer () 是函數呼叫還是透過引用傳遞的Timer 類型的物件。
然而,因為函數在作為參數傳遞時會衰減為指針,所以time_keeper 的真正類型是int(Timer(*)()),這解決了有利於指標的歧義-函數解釋。
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3