c++11 std::forward使用场景以及作用

  • 不使用 std::forward时,下述代码G不管传入什么类型的参数,只会最终调用 void F(int& a);

using namespace std;

 

void F(int& a) {

    cout << "int& version " <<a <<endl;

}

 

void F(int&& a) {

    // do something

    cout << "int&& version " <<a <<endl;

}

 

template<class A>

void G(A &&a) {

    F(a); 

}

 

int main (int argc, char *argv[]) {

    int i = 2;

    G(i); //int& version

    G(5); //int& version

  return 0; 

}

  • 用 std::forward时,G的最终调用出现差异化;

using namespace std;

 

void F(int& a) {

    cout << "int& version " <<a <<endl;

}

 

void F(int&& a) {

    // do something

    cout << "int&& version " <<a <<endl;

}

 

template<class A>

void G(A &&a) {

    F(std::forward<A>(a));

}

 

int main (int argc, char *argv[]) {

    int i = 2;

    G(i); 

    G(5);

    return 0;

}

  • 使用与不使用 std::forward的区别:

函数模板 void G(A &&a)内部是无法知道形参对应的实参,到底是个普通变量,还是濒死的临时变量?

只能原封不动的完美的转发std::forward给函数模板 void G(A &&a)调用的下一层函数。

所以,std::forward转发问题针对的是模板函数。

 

from:https://www.cnblogs.com/rayfloyd/p/14309276.html

 

posted @   imxiangzi  阅读(102)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
点击右上角即可分享
微信分享提示