缓冲区溢出的问题

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

  来讲一下缓存区溢出的原理。在进入到该函数会首先将函数的返回地址写在内存中H,而后函数中用的局部变量定义都会在缓存区中,一开始声明的时候都肯定了各类变量的长度,可是当咱们异常的改变了这个变量的长度,以后,就发生了缓存区溢出的状况,当溢出区覆盖了原先的返回地址,因此在函数结束的时候就报错了。缓存

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

相关文章
相关标签/搜索