ss.str().c_str()的坑

rt


std::stringstream ss;
const char* ch = ss.str().c_str();
call_func(ch);
/***
  这种写法在系统内存不足时,ss会立马释放内存,字符串指针ch可能会非法访问导致崩溃。
  代码最好的是分开写:
***/

std::stringstream ss;
// 独立出std::string
std::string str = ss.str();
const char* ch = str.c_str();
call_func(ch);

Linux下使用 valgrind 工具可以查出上面可能的非法内存访问的问题,也可以查内存泄漏问题。
参见:
std::stringstream ss; 直接使用ss.str().c_str() 字符串指针可能导致崩溃
你有被stringstream坑过吗?

 
喜欢 0
分享