我编写了一个非常简单的程序来进行试验,并与Deleaker一起找出这里可能发生的泄漏:
#include <tchar.h>
#include <windows.h>
#include <Shlobj.h>
int _tmain(int argc, _TCHAR* argv[])
{
DebugBreak(); // I take snapshot here
_TCHAR szFolderPath[520] = _T("");
SHGetFolderPath(NULL, CSIDL_PROGRAM_FILES, NULL, NULL, szFolderPath);
// Then I take snapshot here
// and compare with previous one
DebugBreak();
SHGetFolderPath(NULL, CSIDL_PROGRAM_FILES, NULL, NULL, szFolderPath);
// Finally I take snapshot here
// and compare with previous one
DebugBreak();
return 0;
}
如您所见,我拍摄了 3 张快照。
我拍摄了第一个快照并获得了一些分配:
然后我拍摄第二个快照并计算它与前一个快照之间的差异,以查看 SHGetFolderPath 分配的内容。确实进行了一些分配:
事实上,我怀疑这是一次分配,这是真的:我再次调用 SHGetFolderPath,拍摄新快照并将其与之前的快照进行比较。没有新的分配:
我做了另一个实验来绝对确定。只需启动无限循环并在任务管理器中检查内存使用情况:
while (true)
{
_TCHAR szFolderPath[520] = _T("");
SHGetFolderPath(NULL, CSIDL_PROGRAM_FILES, NULL, NULL, szFolderPath);
}
内存使用似乎很稳定。
所以我认为你不需要关心这个小泄漏。