内存泄露了吗?
is memory getting leaked?
我有一个方法,它接受普通指针到字符串
void parseResponseData(char* response);
我在下面调用它
parseResponseData((char *) response.c_str());
响应是std::string类型。我的假设是,它可能不是转换const char*到char*的最佳方式,其次,在这种情况下,它可能会泄漏内存?需要专家的意见吗?特别是我正在寻找,如果我泄漏内存在这个。
你真的不应该那样强制转换。总的来说,避免在c++中进行c风格的强制转换,并且去除const-ness几乎从来都不是一个好的选择。如果必须从指针中删除const,请使用const_cast
和REALLY尽量避免这种情况。
内存不会泄漏,因为字符串仍然占有它的所有权。
你的问题没有提供足够的信息来明确回答。
为什么parseResponseData
需要一个指向其输入字符串的非const指针?它会修改字符串吗?如果是这样,那么您将无法直接使用std::string
。std::string
不提供任何允许您将其修改为c风格字符串的接口。即使你不想保留这些修改,修改std::string::c_str()
返回的缓冲区仍然是非法的。
如果parseResponseData
没有修改字符串,那么你现在所拥有的应该是有效的(假设parseResponseData
没有试图存储指针以长期使用)。这里没有内存泄漏,因为std::string
对象保留了c_str()
返回的缓冲区的所有权,并负责释放它。然而,它在parseResponseData
部分看起来仍然很难看:如果它是一个非修改操作,它应该使用const char *
.
一旦response
超出作用域,底层C字符串将被释放。对parseResponseData()
的调用不复制C字符串,只复制指针。所以没有内存泄漏。
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 有没有一种方法可以使用placement new将堆叠对象分配给分配的内存