C函数将重复参数绑定到curried函数

我试图理解currying和调用一个函数的概念,该函数连接三个字符串,但只传递两个字符串并使用第二个参数两次.

但是,当我这样做时,第二个参数根本没有被发送到函数,它打印出一个空字符串.这是一个非常明显的错误吗?

string concatthreestrings(string a,string b,string c){
    cout<<"Value of A: "<<a<<endl;
    cout<<"Value of B: "<<b<<endl;
    cout<<"Value of C: "<<c<<endl;
    return a+b+c;
}


int main()
{
    typedef std::function< string( string,string) > fun_t ;
    using namespace std::placeholders;
    fun_t fn = std::bind( concatthreestrings,_1,_2,_2);
    cout<<endl<<fn( "First","Second")<<endl;

}

这是给出以下输出.不使用_2两次意味着第二个和第三个都传递第二个参数.如果在其位置使用字符串,其工作正常.

解决方法

复制字符串很昂贵.由于std :: bind认为占位符的值仅使用一次,因此它对字符串执行std :: move.这是针对每个参数完成的,因此,b或c是移动的,这意味着空字符串.

您可以通过使用const-reference传递参数来明确说出您的意思来更改该行为:

string concatthreestrings(string const& a,string const& b,string const& c)

现在,它应该工作.

相关文章

/** C+⬑ * 默认成员函数 原来C++类中,有6个默认成员函数: 构造函数 析构函数 拷贝...
#pragma once // 1. 设计一个不能被拷贝的类/* 解析:拷贝只会放生在两个场景中:拷贝构造函数以及赋值运...
C类型转换 C语言:显式和隐式类型转换 隐式类型转化:编译器在编译阶段自动进行,能转就转,不能转就编译...
//异常的概念/*抛出异常后必须要捕获,否则终止程序(到最外层后会交给main管理,main的行为就是终止) try...
#pragma once /*Smart pointer 智能指针;灵巧指针 智能指针三大件//1.RAII//2.像指针一样使用//3.拷贝问...
目录&lt;future&gt;future模板类成员函数:promise类promise的使用例程:packaged_task模板类例程...