VC 2010的MFC函数,CMFCVisualManager::GetInstance()可能导致内存泄露
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                VC 2010的MFC函数,CMFCVisualManager::GetInstance()可能导致内存泄露
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.                        
                                今天在網(wǎng)上看到一篇文章,關于CMFCVisualManager的內(nèi)存泄露問題(?鏈接是?http://zhanyonhu.blog.163.com/blog/static/1618604420113208121859/),當然還有其他的關于CMFCButton控件也有內(nèi)存泄露問題,亂七八糟扯蛋,網(wǎng)上很多的誤導文章,寫這個澄清一下。
 
其實他的文章有誤導,使用MFC的新特性功能,你的應用程序類CXXXApp是要繼承于CWinAppEx,而不是CWinApp,這樣就不存在所謂的內(nèi)存泄露。如果重寫了ExitInstance函數(shù),最后也要加一句:
 
 
附:全文摘錄如下
 
VC 2010的MFC函數(shù),CMFCVisualManager::GetInstance()可能導致內(nèi)存泄露。對此,VC2010的MFC類庫并沒有作處理。
導致泄露的代碼位置: \Program Files\Microsoft Visual Studio 10.0\VC\atlmfc\include\afxvisualmanager.h 的 484行。
static CMFCVisualManager* __stdcall GetInstance() { if (m_pVisManager != NULL) { ASSERT_VALID(m_pVisManager); return m_pVisManager; }
if (m_pRTIDefault == NULL) { m_pVisManager = new CMFCVisualManager; ? ? ? ? ? ? ? ? ?//內(nèi)存泄露代碼 } else { m_pVisManager = (CMFCVisualManager*) m_pRTIDefault->CreateObject(); ASSERT_VALID(m_pVisManager); }
m_pVisManager->m_bAutoDestroy = TRUE; m_pVisManager->OnUpdateSystemColors();
return m_pVisManager; }
對VC 2010的此問題,可以使用下面的方法修復: 在C××App中,重載虛函數(shù)ExitInstance,并加入如下代碼:
int?C××App::ExitInstance() { CMFCVisualManager * pVisualManager=CMFCVisualManager::GetInstance(); if (pVisualManager!=NULL) { delete pVisualManager; }
return __super::ExitInstance(); }
總結
以上是生活随笔為你收集整理的VC 2010的MFC函数,CMFCVisualManager::GetInstance()可能导致内存泄露的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: WS_EX_COMPOSITED是个BU
- 下一篇: #region用法
