繁体   English   中英

连接字符串的意外行为

[英]Unexpected behavior concatenating string

我试图在 C++11 中连接两个字符串,但我经常遇到意外行为。

首先,我有一个 function 可以将任何类型转换为字符串:

template <class T>
static inline const char * toStr(T arg) {
    stringstream ss;
    ss << arg;
    return (ss.str()).c_str();
}

然后,我像这样使用这个 function:

string measure_name;
for (unsigned long j = 0; j < 1280; j++) {
    measure_name = string("ADC_") + toStr(j);
    cout << measure_name << endl;
}

一切顺利,直到我达到一个 4 位数(> 999):我的变量measure_name通常等于“ADC_ADC_”......它是随机发生的。 我做了一些研究,并没有发现这种奇怪的行为。

供您参考,如果toStr返回string而不是const char * ,则此问题已得到解决。

另外,如果我尝试打印返回的值,我永远不会看到它等于“ADC_ADC_”,所以我相信真正的问题来自连接指令:

string measure_name;
for (unsigned long j = 0; j < 1280; j++) {
    const char* tmp = toStr(j);
    if (!strcmp(toStr(j), "ADC_ADC_"))
        cout << "bug" << endl; //never happens
    measure_name = string("ADC_") + tmp; //problem comes from here
    cout << measure_name << endl;
}

我只是想了解我在那里做错了什么......我知道我使用的是非常旧的 C++ 但无论如何它应该可以工作。

谢谢你的帮助。

这里

return (ss.str()).c_str();

您正在返回一个指向临时std::string缓冲区的指针(从str()返回)。 从 function 返回的指针对调用者来说是无用的,因为它指向的std::string已经消失了。

指针只是一个指针。 如果你想要一个字符串,返回一个std::string 如果要返回const char* ,则需要将字符串存储在某处并管理其生命周期。

std::string确实管理字符数组的生命周期,所以只需:

template <class T>
static inline std::string toStr(T arg) {
    stringstream ss;
    ss << arg;
    return ss.str();
}

如果有人需要一个char的 c 数组,他们仍然可以调用c_str (只要std::string还活着就可以使用它)。


而不是你的toStr考虑使用std::to_string

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM