c语言的数组下标越界问题

2024-11-23 06:44:56
推荐回答(2个)
回答1:

c++中,并不会自动检查下标越界问题。
第一个程序中,a[10]=a[9],改变了不属于数组空间的内存单元。这个错误不会在编译和连接中反应出来,而是会一直运行下去,知道出现结果不正确。严重时可能导致死机。
第二个程序也是同样道理,数组a只申请了三个整形的内存空间,越界的部分修改了内存中原来的数据。不过在这里编译会报错。
要保证不破坏其他存储空间中的数据只能说自己注意了。

回答2:

二维数组定义的一般形式为:类型说明符
数组名
[常量表达式][常量表达式]
这两个常量表达式分别指定了二维数组的行数和列数,程序编译时据此向内存申请空间。
而引用二维数组的格式为:
数组名[行下标][列下标],行下标和列下标都是从0开始排序。这里的下标和上面的常量表达式意义不同,范围也不同。
以你给的例子来讲:
int
b[4][5]是定义一个名为b的二维数组,它包含4行5列,共20个元素。如果存放数组b的首地址为p,则内存为数组分配的空间是p~p+19;数组b的行下标范围为0~3,列下标范围为0~4,地址p+19存放的元素为b[3][4]。如果要引用b[4][5],由于没有提前向内存申请地址,则会随机指向一个地址,得到一个垃圾数据,无法实现我们的目的,我们就说是引用下标越界。