我正在使用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;
}
答案 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()。 创建一个新的字符串可能是解决这个问题的最简单方法,并且仍然按原样使用该函数。