最近做项目过程中偶尔遇到几次类似的错误,在某个操作时,编译器报:
托管调试助手 "FatalExecutionEngineError":“运行时遇到了错误。
此错误的地址为 0x0794a9e0,在线程 0xe6e4 上。
错误代码为 0x80131623。此错误可能是 CLR 中的 bug,或者是用户代码的不安全部分或不可验证部分中的 bug。
此 bug 的常见来源包括用户对 COM-interop 或 PInvoke 的封送处理错误,这些错误可能会损坏堆栈。”
如果是打包好的客户端软件,做此操作就会卡顿几秒,最后闪退。
造成这类原因的可能性有:
- 局部变量赋值越界
例如: 局部字符串数组拷贝字符串,当拷贝的字符串大大的超过变量空间就会破坏堆栈 - 指向局部变量的指针越界修改数据
例如:void test(int data) { int* p = &data; --p; *p = 100; } - 死循环
死循环会导致栈溢出,从而导致宕机
PS:程序的栈内存空间是向下增长的,堆内存向上增长。以上就是堆栈被破坏的几种情况