先说最近在OJ时,遇到的一个指针的的问题:
int a;
int *t; *t=a;
可能出现错误,及其原因。
t是一个指向整型的指针,因此*t是一个整数。当a赋值给*t有什么不妥?表面看起来没什么问题,更或者运行时,时而正确时而错误。原因是因为t是一个变量(指针也是个变量),所以赋值之前是不能确定的,也就是说在赋值前不知道t指向了哪里。或许指向了一块可以赋值的地方,那运行时就能出正确的结果,若果指向了一块只可以读不可写的地方那么就会出错了。
因此使用指针时要谨慎,学过数据结构的应该知道,使用指针前要将其赋值(NULL),或者专门开辟空间。
段溢出 段错误:
在一个.C文件被编译后会生成一个可执行文件(.exe)。这个可执行文件是由 正文段 储存指令、数据段 储存已初始化的全局变量、BSS段 储存未赋值的全局变量 组成的。
当程序运行时会创建调用栈,调用栈所在的段称为堆栈段。和其他段一样,堆栈段也有自己的大小,不能被越界访问,否则就会出现段溢出错误。
当使用递归时都需要往调用栈里增加一个栈帧,如果递归的很多就会越界。术语就叫栈溢出。