从std :: stringstream传递std :: string引用作为参数

时间:2015-02-10 20:56:00

标签: c++ parameters reference

我正在使用std :: stringstream构造一个字符串,然后尝试传递完成的字符串作为对函数的引用,该函数将std :: string&作为参数。

我在GCC上收到编译错误:

../src/so.cpp:22:21: error: invalid initialization of non-const reference of type ‘std::string& {aka std::basic_string<char>&}’ from an rvalue of type ‘std::basic_stringstream<char>::__string_type {aka std::basic_string<char>}’
../src/so.cpp:12:6: error: in passing argument 1 of ‘void myFunc(std::string&)’
make: *** [src/so.o] Error 1

在Windows VS2012上编译相同的代码,但在我的Linux和Android版本上失败。这是什么原因?

我可以通过暂时将ss.str()分配给临时的std :: string然后通过引用传递该字符串来解决这个问题,但这看起来有些愚蠢。干净利落的正确方法是什么?

#include <iostream>
#include <sstream>

void myFunc (std::string& msg)
{
    std::cout << msg << std::endl;
}

int main (void)
{
    std::stringstream ss;
    ss << "this is a test";

    myFunc (ss.str());              // Fails

    std::string s = ss.str();
    myFunc (s);                     // Pass

    return 0;
}

4 个答案:

答案 0 :(得分:5)

问题是myFunc采用非常量左值引用。 stringstream::str()按值返回字符串。您不能在标准C ++中将临时绑定到非const左值引用,但VS有一个允许此扩展的“扩展”。这就是它编译VS而不是其他编译器的原因。

另一方面,

const左值引用可以绑定到右值。因此,修改你的功能会使它工作:

void myFunc (const std::string &msg) { /* as before */ }

答案 1 :(得分:4)

改变这个:

void myFunc (std::string& msg)

到此:

void myFunc (const std::string& msg)
//           ^^^^^ this will allow temporaries like ss.str()

Visual Studio的某些版本将愚蠢地允许临时绑定到非const引用。然而,它是危险且无效的C ++

答案 2 :(得分:1)

由于您未写入myFunc内的字符串,请接受const引用:

void myFunc (std::string const &msg)
{
  std::cout << msg << std::endl;
}

那些可以绑定到临时对象

答案 3 :(得分:-1)

所以你遇到这个错误的原因是ss.str()返回一个const字符串,而不是一个字符串。 通过创建一个新字符串,您将创建一个非const变量,该变量设置为与ss.str()相同的值,因此可以传递给myFunc()。 创建一个新的字符串可能是解决这个问题的最简单方法,并且仍然按原样使用该函数。