标签:
如图,在调试中发生缓存区溢出的报错。而且是在函数返回的时候发生的。
来说一下缓存区溢出的原理。在进入到该函数会首先将函数的返回地址写在内存中H,然后函数中用的局部变量定义都会在缓存区中,一开始声明的时候都确定了各种变量的长度,但是当我们异常的改变了这个变量的长度,之后,就发生了缓存区溢出的情况,当溢出区覆盖了原先的返回地址,所以在函数结束的时候就报错了。
事实上我发现char了一个长度为64字节的数组,然而在初始化的时候memset了128字节,所以引发了这种错误,还有如sprintf,memcpy之类的内存操作方法都有可能会遇到这种情况。
标签:
原文地址:http://www.cnblogs.com/ssss429170331/p/5909148.html