C 语言指针与数组的深层关联及实战
在 C 语言开发中,指针与数组的关系是理解内存模型的关键。很多初学者容易混淆这两个概念,其实它们既紧密相连又有本质区别。掌握它们的内在联系,能帮助你更灵活地操作内存,写出高效且简洁的代码。
数组名与指针的关系
数组名的本质
在大多数表达式中,数组名会被编译器隐式转换为指向首元素的常量指针。这意味着 arr 和 &arr[0] 在数值上是相等的,都代表数组第一个元素的地址。
#include <stdio.h>
int main() {
int arr[5] = {10, 20, 30, 40, 50};
printf("数组首元素地址:%p\n", arr);
printf("数组首元素地址:%p\n", &arr[0]);
printf("数组首元素值:%d\n", *arr);
return 0;
}
运行结果会显示两个地址相同,且通过 *arr 可以访问到首元素值。这验证了数组名作为指针使用的合法性。
⚠️ 注意:数组名是常量指针,其地址不可修改。尝试对数组名进行自增操作(如 arr++)会导致编译错误。
数组下标与指针的等价关系
C 语言标准规定,数组下标访问 arr[i] 完全等价于指针运算 *(arr + i)。这是指针操作数组的核心逻辑,利用指针算术运算可以灵活访问任意元素。
#include <stdio.h>
int main() {
int arr[5] = {10, 20, 30, 40, 50};
int i;
for (i = 0; i < ; i++) {
(, i, arr[i], i, *(arr + i));
}
;
}


