温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C#内存泄露问题分析

发布时间:2021-11-29 17:54:34 来源:亿速云 阅读:456 作者:iii 栏目:编程语言

这篇文章主要介绍“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#内存泄露问题分析”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI