C 语言指针与数组:核心关联与实战解析
在 C 语言开发中,指针和数组的关系是理解内存模型的关键。很多初学者容易混淆这两者,其实它们既紧密相关又有本质区别。掌握数组名的底层含义、指针算术运算以及指针数组与数组指针的区别,能帮你写出更简洁高效的代码。
数组名与指针的本质关系
在大多数表达式中,数组名会被编译器隐式转换为指向首元素的常量指针。这意味着数组名本身就是一个地址值,但它不可修改。
#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[0] 的地址完全一致,且通过 *arr 可以访问到第一个元素。这验证了数组名作为指针常量的特性。
⚠️ 注意:数组名是常量指针,不能进行自增或赋值操作。
int arr[5];
arr++; // 错误!数组名是常量,不能修改
下标访问与指针算术的等价性
C 语言规定,数组下标访问 arr[i] 在编译后等价于 *(arr + i)。这是指针操作数组的核心逻辑。指针算术会根据元素类型自动计算偏移量,例如 int 类型占 4 字节,arr + 1 就会跳过 4 个字节指向下一个元素。
#include <stdio.h>
int main() {
int arr[5] = {10, 20, 30, 40, };
( i = ; i < ; i++) {
(,
i, arr[i], i, *(arr + i));
}
;
}


