您好,登錄后才能下訂單哦!
這篇文章主要介紹“C#內存泄露問題分析”,在日常操作中,相信很多人在C#內存泄露問題分析問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”C#內存泄露問題分析”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
今天在看國外的一篇技術文章的時候,發現有人就在研究這個問題!他給出了一種解決辦法。首先把他介紹,操作系統會為每一個系統中運行的線程分配一個數據結構叫做TIB(Thread Information Block)或者叫TEB(Thread Enviroment BLock)。里面記錄了與某個線程相關的所有信息。當然包括線程相關的堆棧地址信息。而堆棧的棧頂與棧基址分別存放在FS寄存器的4與8位置處。所以他通過嵌入式匯編實現了判斷指針是棧指針,還是堆指針的方法。代碼如下:
bool IsMemoryOnStack( LPVOID pVoid ) { LPVOID dwStackTop = 0; LPVOID dwStackLowCurrent = 0; __asm { mov EAX, FS:[4] mov dwStackTop, eax mov EAX, FS:[8] mov dwStackLowCurrent, eax } if( pVoid < = dwStackTop && pVoid >= dwStackLowCurrent ) { // The memory lie between the stack top and stack commited. return true; } // Pointer dosen't point to the stack return false; }
現在只需要把CTest可能引起內存泄漏的函數修改為如下,就可以解決問題了:
CTest(CTest* & t) { this->x=t->getX(); if(!IsMemoryOnStack(t)) { delete t; t=0; } }
這里使用指針引用的好處是在防止在釋放了指針的內存后,用戶繼續訪問指針的內存。
到此,關于“C#內存泄露問題分析”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。