关于std::string::stringstream.str().c_str()的问题

在做项目时遇到了一个算是低级但是很容易忽略的问题,先来看下面的语句。

result1 << std::fixed << std::setprecision(farZ < 100 ? 1 : 0) << farZ;
const char* tmp = result1.str().c_str();

看上去似乎没什么问题,但运行时却tmp拿不到相应的数据,断点调试发现result.str()是有值的,那么问题就出现在后面的.c_str()上了。
关于std::string::stringstream.str().c_str()的问题_第1张图片
result.str()有值,“948”。
在这里插入图片描述

1.问题发现

首先看一下c_str(),其作用为“返回指向以空结尾的不可变数组的指针”,也就是会返回指向result1.str()所返回的字符数组。
问题就是出现在这里,当result1.str()返回时,原本存储其内容的内存已经释放掉(局部变量超出作用域,析构函数释放内存),所以再用一个指针指向他是没有用的,而且指针会指向随机的地址。

在一些单线程的程序,这样的操作可能不会引起什么,最多也是指向一块空地址,但在多线程程序中,内存可能会被其他线程快速地使用,

2.问题解决

最简单的方法就是搞个中间变量,先把result.str()的值用一个临时变量存储,后面再调用.c_str()。

std::string temp = result1.str();
const char* tmp = temp.c_str(); 

关于std::string::stringstream.str().c_str()的问题_第2张图片
涉及传参时,很容易忽略去考虑传进去的参数是否存在,其内存空间有没有被释放等问题。

参考文章:https://blog.sensecodons.com/2013/04/dont-let-stdstringstreamstrcstr-happen.html

你可能感兴趣的:(项目小结)