假设您有一个包含四个元素的数组。那么,数组索引将从0到3,即我们可以访问索引0到3的元素。
但是,如果我们使用大于3的索引,它将被称为索引越界。
如果我们使用越界的数组索引,那么编译器将编译甚至运行。但是,不能保证结果正确。
结果可能不确定,并且会导致许多问题。因此,建议在使用数组索引时要小心。
以下是数组中索引越界的 C 程序 -
现场演示#include<stdio.h> int main(void){ int std[4]; int i; std[0] = 100; //valid std[1] = 200; //valid std[2] = 300; //valid std[3] = 400; //valid std[4] = 500; //invalid(out of bounds index) //printing all elements for( i=0; i<5; i++ ) printf("std[%d]: %d</p><p>",i,std[i]); return 0; }
当执行上述程序时,会产生以下结果 -
std[0]: 100 std[1]: 200 std[2]: 300 std[3]: 400 std[4]: 2314
在这个程序中,数组大小为4,因此数组索引将从std[0]到std[3]。但是,这里我们将值 500 赋给了 std[4]。
因此,程序已成功编译并执行。但是,在打印该值时,std[4] 的值是垃圾。我们在其中分配了 500,结果是 2314。
以上是在C语言中,什么是数组的越界索引?的详细内容。更多信息请关注PHP中文网其他相关文章!