我有一个接受std::string&的函数
void f(std::string& s) { ... }我有一个const char*,它应该是该函数的输入参数。这样做是可行的:
const char* s1 = "test";
std::string s2{s};
f(s2);这并不是:
const char* s1 = "test";
f({s1});为什么这不可能?有趣的是,CLion IDE没有抱怨,但编译器是:
no known conversion for argument 1 from ‘<brace-enclosed initializer list>’ to ‘std::basic_string<char>&’发布于 2016-10-24 19:31:54
这与从std::string构建char const*无关。
f需要一个字符串的lvalue,通过当场创建一个临时实例,您将提供一个rvalue,它不能绑定到一个非const值引用。f(string{})同样是无效的。
发布于 2016-10-24 19:40:28
您的函数接收一个非const引用,并且正在传递一个临时对象,该对象需要一个副本或一个const引用参数。两个解决方案,创建另一个函数作为rvalue引用接收对象,并在其中调用另一个重载。
void f(string&& s) { f(s); } 允许临时对象作为参数,或更改函数定义以接收除作为常量引用以外的任何对象
void f(const std::string& s) { ... }发布于 2016-10-24 19:32:19
一种选择是将函数更改为按值而不是引用来接受字符串。那就成功了。在任何情况下,在C++11中,有时最好是通过值传递,而不是引用。
https://stackoverflow.com/questions/40225952
复制相似问题