繁体   English   中英

在C ++中转发params

[英]Forwarding params in C++

我有一些课程和包装。 例如:

#include <iostream>
#include <string>

template<typename T>
class inner
{
public:
    void f(T& v) { std::cout<<"lvalue: "<<v<<std::endl;}
    void f(T&& v) { std::cout<<"rvalue: "<<v<<std::endl;}
};

template<typename T>
class wrapper
{
public:
    template<typename _T>
    void f(_T&& v) { i.f(std::forward<T>(v)); } //(1)

private:
    inner<T> i;
};

int main()
{
    wrapper<std::string> c;
    //inner<std::string> c;

    c.f("r");

    std::string s = "l";
    c.f(s);
}

cinner输出的情况下是正确的:

rvalue: r
lvalue: l

但是当cwrapper输出不正确时:

rvalue: r
rvalue: l

为什么l值成为r值?

如果在第(1)行上wrapperf定义有什么区别:

    template<typename _T>
    void f(_T v) { i.f(std::forward<T>(v)); } //without &&

因为你在做:

template<typename _T>
void f(_T&& v) { i.f(std::forward<T>(v)); } //(1)
                                  ^
                                  T, not _T

你总是只使用T ,而不是推导出v类型。 为了更加清晰,你实际上在做:

template <typename _T>
void f(_T&& v) {
    i.f(std::forward<std::string>(v));
}

std::forward<std::string>(v)string&&

对于你的第二个问题:

template<typename _T>
void f(_T v) { i.f(std::forward<T>(v)); } //without &&

由于_T在这里永远不会推断为引用类型,因此std::forward<T>(v)将等同于std::move(v) - 它只是一个转换为右值引用。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM