中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++編程之std::forward使用代碼分析

發布時間:2023-03-22 16:30:02 來源:億速云 閱讀:195 作者:iii 欄目:開發技術

今天小編給大家分享一下C++編程之std::forward使用代碼分析的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

std::forward 是一個 C++11 中的模板函數,其主要作用是在模板函數或模板類中,將一個參數以“原樣”(forward)的方式轉發給另一個函數。通常情況下,該函數被用于實現完美轉發(perfect forwarding)。

完美轉發是指,一個函數或類模板可以將其參數原封不動地轉發給另一個函數或類模板,同時保持被轉發參數的左右值特性(lvalue 或 rvalue)。它在實現泛型編程時非常有用,因為它可以避免重復編寫代碼,同時提高代碼的可復用性。

在 C++ 中,函數參數可以是左值引用(lvalue reference)或右值引用(rvalue reference)。對于一個模板函數或類模板,當傳遞一個參數時,如果該參數是左值,那么傳遞的就是一個左值引用;如果該參數是右值,那么傳遞的就是一個右值引用。

通常情況下,在將參數轉發給其他函數時,我們需要保留原始參數的左右值特性。這就是 std::forward 函數的作用,它可以將一個參數的左右值特性原封不動地轉發給其他函數。

下面是一個使用 std::forward 的例子:

#include <iostream>
#include <utility>

void func(int& x) {
    std::cout << "lvalue reference: " << x << std::endl;
}

void func(int&& x) {
    std::cout << "rvalue reference: " << x << std::endl;
}

template<typename T>
void wrapper(T&& arg) {
    func(std::forward<T>(arg));
}

int main() {
    int x = 42;
    wrapper(x);  // lvalue reference: 42
    wrapper(1);  // rvalue reference: 1
    return 0;
}

在上面的例子中,我們定義了兩個函數 func,一個接受左值引用,另一個接受右值引用。然后我們定義了一個模板函數 wrapper,它的參數是一個完美轉發引用(perfect forwarding reference) T&&。在 wrapper 函數中,我們使用 std::forward 函數將參數 arg 轉發給 func 函數。通過使用 std::forward,我們可以確保 func 函數接收到的參數的左右值特性與原始參數保持一致。

  • 當向wrapper里面傳入x的時候,wrapper推導認為 T是一個左值引用int &,通過引用折疊原則(看萬能引用文章)int && + & = int &,相當于wrapper(int& arg),同時我們知道了T推導為int&,那么在向func傳遞的時候,就是func(std::forward<int&> (arg)) ,那么func會以左值引用的形式 func(int& x) 調用arg。

  • 當向wrapper里面傳入1的時候,wrapper推導認為T是一個右值引用int&& ,通過引用折疊原則,int && + && =int&& ,相當于wrapper(int&& arg),同時我們知道了T推導為int&&,那么在向func傳遞的時候,就是func(std::forward<int&&>(arg)),那么func會以左值引用的形式func(int&& x)調用arg。

簡單來說,當傳遞給 wrapper 函數的參數是右值時,T 會被推導為右值引用類型 int&&,此時 std::forward(arg) 的返回值類型為 int&&,將會調用 func(int&&)。當傳遞給 wrapper 函數的參數是左值時,T 會被推導為左值引用類型 int&,此時 std::forward(arg) 的返回值類型為 int&,將會調用 func(int&)。

當我們把std::forward去掉的話,那么當傳入一個具名變量參數時,func會認為這個值就是是一個左值。當傳入一個臨時變量(不具名變量)參數的時候,func會認為這個值就是一個右值。

#include <iostream>
#include <utility>

void func(int&& x) {
    std::cout << "rvalue reference: " << x << std::endl;
}

void func(int& x) {
    std::cout << "lvalue reference: " << x << std::endl;
}

template<typename T>
void wrapper(T&& arg) {
    func(arg);
    func(1);
}

int main() {
    int x = 42;
    wrapper(x);  // lvalue reference: 42
    wrapper(10);  // rvalue reference: 1
    return 0;
}

輸出:

lvalue reference: 42
rvalue reference: 1
lvalue reference: 10
rvalue reference: 1

這樣的結果就是不能對arg推導出的類型完美轉發到其他函數中,顯然不符合本意。

以上就是“C++編程之std::forward使用代碼分析”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

江都市| 富宁县| 德格县| 定边县| 莲花县| 慈利县| 清涧县| 佛坪县| 永昌县| 临汾市| 班玛县| 莎车县| 康定县| 柘城县| 勃利县| 离岛区| 望江县| 元阳县| 舟曲县| 无极县| 闽清县| 永城市| 蓝田县| 壶关县| 仪征市| 铜陵市| 古丈县| 阳朔县| 黄梅县| 淳化县| 广州市| 桐柏县| 罗源县| 襄汾县| 宜君县| 广元市| 寻乌县| 庆安县| 绵竹市| 濉溪县| 城口县|