缓冲区溢出的问题

如图,在调试中发生缓存区溢出的报错。而且是在函数返回的时候发生的。

  来说一下缓存区溢出的原理。在进入到该函数会首先将函数的返回地址写在内存中H,然后函数中用的局部变量定义都会在缓存区中,一开始声明的时候都确定了各种变量的长度,但是当我们异常的改变了这个变量的长度,之后,就发生了缓存区溢出的情况,当溢出区覆盖了原先的返回地址,所以在函数结束的时候就报错了。

  事实上我发现char了一个长度为64字节的数组,然而在初始化的时候memset了128字节,所以引发了这种错误,还有如sprintf,memcpy之类的内存操作方法都有可能会遇到这种情况。

posted @ 2016-09-26 14:41  深空灰  阅读(282)  评论(0编辑  收藏  举报