我有一个返回字符串的函数。但是,当我调用它并对其执行c_str()以将其转换为const char *时,它仅在我首先将其存储到另一个字符串时才起作用。如果我直接从函数中调用c_str(),它会将垃圾值存储在const char *中。
为什么会这样?感觉我在这里遗漏了一些非常基本的东西......
string str = SomeFunction();
const char* strConverted = str.c_str(); // strConverted stores the value of the string properly
const char* charArray= SomeFunction().c_str(); // charArray stores garbage value
static string SomeFunction()
{
string str;
// does some string stuff
return str;
}
SomeFunction().c_str()
给你一个临时指针(自动变量) str
在体内 SomeFunction
)。与参考文献不同,在这种情况下,临时工的生命周期并没有延长,你最终得到了 charArray
是一个悬空指针,解释了你在以后尝试使用时看到的垃圾值 charArray
。
另一方面,当你这样做
string str_copy = SomeFunction();
str_copy
是一个返回值的副本 SomeFunction()
。调用 c_str()
现在,它为您提供了指向有效数据的指针。
函数返回的值对象是临时的。结果 c_str()
仅在临时的有效期内有效。在大多数情况下,临时的生命周期是完整表达式的结尾,通常是分号。
const char *p = SomeFunction();
printf("%s\n", p); // p points to invalid memory here.
解决方法是确保使用结果 c_str()
在完整表达结束之前。
#include <cstring>
char *strdup(const char *src_str) noexcept {
char *new_str = new char[std::strlen(src_str) + 1];
std::strcpy(new_str, src_str);
return new_str;
}
const char *p = strdup(SomeFunction.c_str());
注意 strdup
是一个POSIX函数,所以如果你是一个支持POSIX的平台,它已经存在了。
使用strcpy将字符串复制到本地定义的数组,您的代码将正常工作。