如何用指针遍历数组?1. 利用指针算术运算逐个访问数组元素;2. 数组名可视为指向首元素的指针,但不可修改;3. 遍历时定义指针指向数组起始地址,通过ptr++移动并设置终止条件防止越界;4. 注意避免越界访问、类型不匹配、修改常量区数据等问题;5. 多维数组遍历时需注意内存布局,可按行连续访问或转换为一维方式处理。

用指针遍历数组,本质上是利用指针的算术运算能力来逐个访问数组元素。在C++中,数组名在大多数情况下会被视为指向数组第一个元素的指针,因此我们可以通过指针操作来实现高效的数组访问。

指针和数组的关系
在C++中,数组和指针有着天然的联系。例如:

int arr[5] = {1, 2, 3, 4, 5};
int* ptr = arr;这里 arr 实际上会被当作 &arr[0],也就是指向数组第一个元素的指针。于是我们可以使用 ptr 来访问数组中的每一个元素。
立即学习“C++免费学习笔记(深入)”;
需要注意的是:虽然数组名可以被当指针使用,但它不是一个变量,不能进行自增等操作,而指针变量是可以改变指向的。

使用指针遍历数组的基本方法
要遍历一个数组,基本思路是:
- 定义一个指针指向数组的起始位置;
- 利用指针算术(如
ptr++)逐步移动到下一个元素; - 设置终止条件,防止越界访问。
举个例子:
int arr[] = {10, 20, 30, 40, 50};
int size = sizeof(arr) / sizeof(arr[0]);
for (int* ptr = arr; ptr < arr + size; ptr++) {
std::cout << *ptr << " ";
}上面这段代码中:
-
arr + size表示数组最后一个元素的下一个地址; - 每次循环
ptr++就是让指针往后移动一个int类型的大小; -
*ptr取出当前指针对应的值。
这种方式效率高,尤其适用于对性能敏感的场景。
注意事项与常见问题
遍历数组时,如果不小心,容易出现一些错误,比如:
- 越界访问:没有正确判断结束条件,导致访问非法内存;
-
类型不匹配:比如用
char*遍历int数组,指针移动步长就会出错; -
修改常量区数据:如果数组是字符串字面量(如
char* str = "hello"),尝试通过指针修改内容会导致未定义行为。
几个实用建议:
- 始终确保指针不会超出数组边界;
- 使用
sizeof(array)/sizeof(array[0])获取数组长度; - 如果不想修改原始指针,可以用临时指针来遍历;
- 对于固定大小的数组,优先考虑使用
std::array或std::vector,配合迭代器会更安全。
在多维数组中的应用
指针也可以用来遍历二维数组,但要注意类型匹配。比如:
int matrix[2][3] = {{1, 2, 3}, {4, 5, 6}};
int (*ptr)[3] = matrix;
for (int i = 0; i < 2; i++) {
for (int j = 0; j < 3; j++) {
std::cout << ptr[i][j] << " ";
}
}或者使用更底层的方式:
int* p = &matrix[0][0];
for (int i = 0; i < 6; i++) {
std::cout << *(p + i) << " ";
}关键点在于理解二维数组在内存中是按行连续存储的,所以可以看作一维数组来处理。
基本上就这些。掌握好指针算术和数组布局,遍历数组就不是难事。









