数组名是指向首元素的指针常量,不可赋值,保留类型和长度信息;2. 指针可指向数组并用下标访问元素,但sizeof运算结果不同,体现本质区别。

在C++中,数组和指针看似相似,实则有本质区别,但又紧密关联。理解它们之间的关系对掌握内存操作和高效编程至关重要。很多人容易混淆两者,尤其是在函数传参或动态内存处理时。下面从几个关键角度解析数组与指针的关系。
数组名的本质是指针常量
定义一个数组时,如:
int arr[5] = {1, 2, 3, 4, 5};数组名 arr 在大多数表达式中会被自动转换为指向其首元素的指针,即 &arr[0]。这意味着:
- arr 的值是首元素地址
- arr 不能被赋值(它是常量指针)
- sizeof(arr) 得到的是整个数组的字节大小,而不是指针的大小
例如,在32位系统中,sizeof(arr) 是 20(5个int),而 sizeof(int*) 是 4。这说明数组名不是普通指针,它保留了类型信息和长度信息(在作用域内)。
立即学习“C++免费学习笔记(深入)”;
指针可以指向数组并模拟数组访问
指针可以通过下标或偏移访问数组元素。例如:
int* p = arr; // p 指向 arr 首元素cout cout
这种等价性源于C++的地址运算规则:p[i] 等价于 *(p + i)。因此,只要指针指向一段连续内存,就可以像数组一样使用。
动态分配数组时更是如此:
int* dyn_arr = new int[5];dyn_arr[0] = 10;
这里 dyn_arr 是指针,但它完全以数组方式使用。
云点滴客户解决方案是针对中小企业量身制定的具有简单易用、功能强大、永久免费使用、终身升级维护的智能化客户解决方案。依托功能强大、安全稳定的阿里云平 台,性价比高、扩展性好、安全性高、稳定性好。高内聚低耦合的模块化设计,使得每个模块最大限度的满足需求,相关模块的组合能满足用户的一系列要求。简单 易用的云备份使得用户随时随地简单、安全、可靠的备份客户信息。功能强大的报表统计使得用户大数据分析变的简单,
函数参数中数组退化为指针
当数组作为函数参数传递时,会“退化”为指针。例如:
void func(int arr[]) { }// 等同于
void func(int* arr) { }
这意味着在函数内部无法通过 sizeof(arr) 获取数组真实长度,因为此时 arr 是指针。必须额外传入长度参数:
void printArray(int* arr, int size) {for (int i = 0; i cout }
这也是为什么推荐使用 std::vector 或 std::array 的原因之一——它们能携带大小信息。
数组指针与指针数组的区别
理解以下两种声明有助于深入掌握关系:
- int (*ptr)[5]; —— ptr 是指向含有5个int的数组的指针
- int* arr[5]; —— arr 是包含5个int指针的数组
前者可用于多维数组处理,例如:
int matrix[3][5];int (*p)[5] = matrix; // p 指向二维数组的第一行
每次 p++ 会跳过一整行(5个int),体现数组指针的步长特性。
基本上就这些。数组和指针在语法层面高度兼容,但在语义和行为上各有特点。掌握它们的转换规则和限制,能避免常见错误,写出更清晰、安全的代码。









