C语言的编译器为什么不检查数组下标越界?

  C语言的编译器是不检查下标越界的,以前知道这个问题,可是没有想过是什么原因?昨天中兴的笔试题问到了,就在网上查了一下,总结如下:
  1,不检查下标是否越界可以有效提高程序运行的效率,因为如果你检查,那么编译器必须在生成的目标代码中加入额外的代码用于程序运行时检测下标是否越界,这就会导致程序的运行速度下降,所以为了程序的运行效率,C/C++才不检查下标是否越界。
  2,
不检查下标是为了给程序员更大的空间,也为指针操作带来更多的方便。如果有这个检查的话指针的功能将会大大被削弱,C的数组标识符,里面并没有包含该数组 长度的信息,只包含地址信息,所以语言本身无法检查,只能通过编译器检查,而早期的C语言编译器也不对数组越界进行检查,只能由程序员自己检查确保。以及 在早期的CRT函数中也不对字符串指针或数组进行越界检查,都是要求程序员确保空间足够,因此也才也才有了在VS2005之后微软提供的安全的CRT函数 版本。  

  自己写了一段检测程序测试这个问题,发现如果数组下标越界了,那么它会自动接着那块内存往后写。想了一下明白了,以前说不允许数组下标越界,并不是 因为界外没有存储空间,而是因为界外的内容是未知的。也就是说如果界外的空间暂时没有被利用,那么我们可以占用那块内存,但是如果之前界外的内存已经存放 了东西,那么我们越界过去就会覆盖那块内存,导致错误的产生。。。

这样就明白了,所以我们还是需要好好规划数组的下标滴。
posted @ 2011-09-19 10:48  潜龙9527  阅读(369)  评论(0编辑  收藏  举报