C++踩坑记录(一)std:;string的析构

之前写服务端程序有一个往消息队列里面推json的过程,然后发现推进去C#端取到的无论如何都是个空指针 简单复现一下现场

string str1 = string("hello1");
string str2 = string("hello2");
const char* ptr1 = str1.substr(1).data();    // 取字符串从下标1到结尾的部分
const char* ptr2 = str2.substr(1).data();
cout << ptr1 << ptr2 << endl;

这样看起来输出是ello1ello2的输出,在我笔记本上面挺正常的,实际上我集成到服务器上面的时侯炸了,一直取到一组奇怪的字符串 跟踪调试了一早上(虽然写了3年C++工程,但是还是菜吧,折腾了好久)。 原来在str1.substr(1)创建了一个临时对象存储str1的子串。data()函数获取了这个子串的内存指针。

执行到到了下一行的时候,存储str1子串的字符串对象被析构,msvc发现这是个临时对象,代码块还没结束的十好几就把内存析构掉,临时对象的内存被释放,同时str2.substr(1),这个时候新的临时变量被注册到刚才str1.substr(1)被析构掉的内存地址上面,此时再去调用data(),拿到了ptr1同一个地址的指针,此时内存的数据变更为s2的子串,然后压到消息队里面的数据穿就乱了,当我把程序增加一个临时string去接收上面产生的子串的时候,问题就会解决了

string str1 = string("string1");
string str2 = string("string2");
string t_str1 = str1.substr(1);
string t_str2 = str2.substr(1);
const char* ptr1 = t_str1.data();
const char* ptr2 = t_str2.data();
cout << ptr1 << ptr2 << endl;
原文地址:https://www.cnblogs.com/wangshaowei/p/11190714.html