41.C语言 数组下标越界

最后更新于:2020-08-21 23:07:36

一.数组下标越界简介

1、什么是数组访问越界?

C语言中,我们可以直接通过数组下标来访问数组中的元素;

如果一个数组定义为有n个元素,那么,对这n个元素(下标为0n-1的元素)的访问都合法,如果对这n个元素之外的访问,就是非法的,称为越界,例如:

int a[5] = {0}; //等价 int a[5] = {0,0,0,0,0};

a[0] = 1;  // ok
a[1] = 2;  // ok
a[2] = 3;  // ok
a[3] = 4;  // ok
a[4] = 5;  // ok
a[5] = 6;  // 数组下标越界

在上面代码中,声明一个数组a[5],该数组中只能存放5个元素,下标索引值取值范围0~4,超过这个范围就属于下标越界;

2、访问越界会出现什么结果?

首先,它并不会 造成编译错误!就是说,C,C++的编译器并不判断和指出你的代码访问越界了。一个明明是错误的东西,就这样“顺利”地通过了编译;

数组访问越界在运行时,它的表现是不定的,有时似乎什么事也没有,程序一直运行(当然,某些错误结果已造成);有时,则是程序一下子崩溃。因此在使用数组时,一定要在编程中判断是否越界以保证程序的正确性。

二.数组下标越界案例

/************************************************************************/
/*@文件名      : 数组下标越界案例.cpp
/*@日  期      : 2020/07/25 21:52
/*@作  者      : 猿说编程
/*@公众号      : 猿说编程
/*@博客        : www.shuopython.com
/*@描述        : C语言教程 - 数组下标越界案例
/************************************************************************/

#include <stdio.h>

int main()
{
    int i, a[10];
    for(i = 1; i <= 10; ++i)
        a[i] = 0;
    return 0;
}

数组中的下标从0开始,那么在上面代码中只能访问:a[1]a[2]a[3]a[4]a[5]a[6]a[7]a[8]a[9];i自加到10时,a[10]属于数组下标越界。

三.防止数组下标越界方法

如果数组的长度和下标访问值弄错,都会造成数组下标越界;数组的下标是从0开始的,最大的访问值是数组的长度-1;

//如果是整形数组
int len = sizeof(array)/sizeof(int);
//如果是字符数组
int len = sizeof(array)/sizeof(char);
//如果是浮点数数组
int len = sizeof(array)/sizeof(double);
//如果是浮点数数组
int len = sizeof(array)/sizeof(float);

for(int i = 0;i < len ; i++)
{
    //.....
}


猜你喜欢

1. 三目运算符

2. 逗号表达式

3. NaN(Not a Number)

4. memcpy/strcpy/strcpy_s 区别

5. unicode 和多字节区别

6. 数组定义和使用

7. sizeof和strlen函数区别

8. Debug和_DEBUG区别

9. _WIN32/WIN32/_WIN64/WIN64区别

10. 判断exe可执行程序是32位的还是64位

11. 十进制和二进制相互转换

12. 十进制和八进制相互转换

13. 十进制和十六进制相互转换




转载请注明: 猿说编程 » C/C++教程 » 数组下标越界

赞赏

微信赞赏支付宝赞赏