信息产业部电子第30研究所
魏刚
我最近在程序开发中发现我的一个程序运行一段时间以后,就会导致系统崩溃,初步分析以后,得出得结论是有内存泄漏。
经使用NuMega BoundsChecker分析以后发现都是一些系统文件中动态分配的内存模块没有被释放,由于这些new都在VC调用的系统文件中无法用调试的方法更正。于是我生成了一个我的程序的MFC外壳,后台的消息处理一条也不处理。检查发现还是有内存泄漏。我的程序外壳是单文档的,VIEW类是从CFormView继承来的,BoundsChecker分析结果如下:
一次偶然的机会我发现我的一些错误的产生被BoundsChecker指向了
IMPLEMENT_DYNCREATE(CTest1View, CFormView)
即VC中的动态生成宏。既内存的泄漏与MFC的基类中的NEW有关,
由此我在视类的虚析构函数中设置了断点,调试发现果然程序退出时没有执行到
视类的析构函数,当然就会发生内存泄露了,进一步分析发现:原来我在程序中
为了在退出时显示一个与splash screen类似的窗口,而重载了退出函数,
void CTest1View::OnAppExit()
{
//闪现splash screen窗口...........
AfxGetMainWnd()->PostMessage(WM_QUIT);
}
最后使用了向窗口发送退出消息的方法来退出程序,这种方式绕过了一些
窗口的退出时的析构处理,导致了程序的出错。
由此可见,我们在编程的时候一些看似正确,编译运行通过的程序也可能
有一些隐藏的BUG,我的程序也是在长时间不间断的运行中才发现的问题,
而一些不长时间运行的程序,就有可能忽略了这样的问题。而且使用
AfxGetMainWnd()->PostMessage(WM_QUIT); 的方式来退出程序是我在许多编程
网站上看到的推荐方法。