C语言下标越界问题
C语言程序在运行过程中,系统并不自动检查数组元素的下标是否越界,有时数组两端越界会破坏其他存储单元中的数据。问:因为有时我在运行数组下标越界的数组时也会得到正确的程序结果...
C语言程序在运行过程中,系统并不自动检查数组元素的下标是否越界,有时数组两端越界会破坏其他存储单元中的数据。
问: 因为有时我在运行数组下标越界的数组时也会得到正确的程序结果。 那么 什么情况下 数组下标越界是否会破坏程序?? 如何知道一个程序中数组元素越界是否会破坏程序? 有没有什么判断方法???? 展开
问: 因为有时我在运行数组下标越界的数组时也会得到正确的程序结果。 那么 什么情况下 数组下标越界是否会破坏程序?? 如何知道一个程序中数组元素越界是否会破坏程序? 有没有什么判断方法???? 展开
4个回答
展开全部
越界有危险,但是没有办法判断,
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
第二个循环条件写错了吧
循环里i只要小于等于6就会死循环了
比如第一次i为零时就会一直让j自增跳不出循环自然了j大过数组下标最大值时就越界了
循环里i只要小于等于6就会死循环了
比如第一次i为零时就会一直让j自增跳不出循环自然了j大过数组下标最大值时就越界了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
二维数组定义的一般形式为:类型说明符
数组名
[常量表达式][常量表达式]
这两个常量表达式分别指定了二维数组的行数和列数,程序编译时据此向内存申请空间。
而引用二维数组的格式为:
数组名[行下标][列下标],行下标和列下标都是从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],由于没有提前向内存申请地址,则会随机指向一个地址,得到一个垃圾数据,无法实现我们的目的,我们就说是引用下标越界。
数组名
[常量表达式][常量表达式]
这两个常量表达式分别指定了二维数组的行数和列数,程序编译时据此向内存申请空间。
而引用二维数组的格式为:
数组名[行下标][列下标],行下标和列下标都是从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],由于没有提前向内存申请地址,则会随机指向一个地址,得到一个垃圾数据,无法实现我们的目的,我们就说是引用下标越界。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询