為什麼右邊值引用參數可以綁定到左值參數
在 C 中,右值引用應該綁定到右邊值。然而,在某些情況下,右值引用參數可以匹配左值參數,這讓許多程式設計師感到驚訝。
考慮以下程式碼:
void f(T&&); // #1 void f(T&); // #2
通常,我們預期 f(T&&)傳遞右邊值時呼叫重載,傳遞左值時呼叫 f(T&) 重載。但是,行為不同:
void g(T&& t) { f(t); // calls #2 }
在此範例中,即使 t 是右值,也會呼叫 f(T&) 重載。發生這種情況是因為,儘管它是右值引用類型,t 仍然被視為左值。
基本原理:
右值通常是沒有名稱的實體或將失去名稱的實體名字很快。右值引用只能綁定到右值。但是,t 有名稱,而且它的生命週期不會立即過期。
T&& 型別:
T&& 是右邊值所引用的型別。雖然它只能綁定到右值,但它在其他方面表現為右值引用類型的左值。它的右值引用性質僅在其建構期間和執行 decltype(variable_name) 時才重要。
std::move() 的作用:
std::move( )透過執行傳回一個右邊值參考static_cast
相關規則:
以上是C 中什麼時候可以將右值引用參數綁定到左值參數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!