问题源于一条简单的代码
.....
char * ps;
ps = new char[strlen(animal)];
.......
delete [] ps;
........
编译通过后在Debug模式下出现
这个错误网上解释为数组访问越界.
最终源头出自 ps = new char[] ,分配堆时出现的错误.指定长度应加1
改为 ps = new char[strlen(animal) + 1] 程序将不再会报错
当给ps 所指的内存空间分配字符串是,cin或者strcpy() ,会在字符串尾部自动加'\0'. 导致访问数组内存越界.
在网上有的解释可能是dll(dynamic link library)调用问题. 然而我同学的代码好并没有涉及到此.
ESP是指针寄存器的一种(另一种为EBP)。用于堆栈指针。
ESP为堆栈指针,用于指向堆栈的栈顶(下一个压入堆栈的活动记录的顶部),而EBP为帧指针,指向当前活动记录的顶部。 栈指针与帧指针标识出了当前活动记录的位置。此次错误原因因为定义整形数组a[7]却给其赋了8个二进制数.导致调用convert函数时候使得程序崩溃.
当编写程序定义一个数组时应注意下标大小与存储元素之间的关系,避免程序出现不易察觉的错误.