c++ MFC:从Char*创建CString时内存泄漏
C++ MFC: Memory Leak When Creating CString From Char*
当我运行尝试从剪贴板读取时,我正在获得内存泄漏。
示例代码:void SomeFunction()
{
OpenClipboard(nullptr);
HGLOBAL hglb = GetClipboardData(CF_TEXT);
char* ch = static_cast<char*>(GlobalLock(hglb));
CString rawClipboardData(ch);
GlobalUnlock(hglb);
CloseClipboard();
}
根据Visual Studio,导致内存泄漏的是上面的中间行。这一行:
CString rawClipboardData(ch);
如果我不运行它,则不会报告泄漏。但是如果我运行它,我会在visual studio输出窗口中得到以下调试输出:
Detected memory leaks!
Dumping objects ->
f:ddvctoolsvc7libsshipatlmfcsrcstrcore.cpp(158) : {75645} normal block at 0x00000000072C89A0, 52 bytes long.
Data: <`x > 60 78 F7 D3 FE 07 00 00 0D 00 00 00 0D 00 00 00
Object dump complete.
任何想法?
更新:在上面的代码中添加了OpenClipboard(nullptr)。在实际代码中也有null检查。保持这里的整洁可以减少guard子句代码的数量。
GlobalLock(hglb)应该是LPTSTR
,所以我假设泄漏是由转换到char*
引起的。对于Unicode平台,TCHAR被定义为WCHAR类型的同义词。
你应该能够做一些像
CString rawClipboardData = GlobalLock(hglb);
如果没有,则
CString rawClipboardData;
LPTSTR lptstr = GlobalLock(hglb);
rawClipboardData = lptstr;
一定可以
相关文章:
- 将字符串存储在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的内存
- 对树节点使用 CString 时出现内存泄漏
- 使用后需要删除CString以释放内存
- CString -> 内存泄漏数组?
- c++ MFC:从Char*创建CString时内存泄漏