在C++中,指向整个数组的指针(通常称为“数组指针”)是指向一个固定大小数组类型的指针。它和指向数组第一个元素的指针不同,数组指针保存的是整个数组的地址,类型信息包含数组的长度。
声明数组指针
数组指针的声明语法如下:
类型名 (*指针名)[数组大小];
例如,声明一个指向包含5个int元素的数组的指针:
int (*ptr)[5];
这表示ptr是一个指针,它指向一个有5个int元素的数组。
立即学习“C++免费学习笔记(深入)”;
初始化和使用数组指针
定义一个数组后,可以将它的地址赋给数组指针。注意要使用取地址符&,因为数组名本身会退化为指向首元素的指针。
int arr[5] = {1, 2, 3, 4, 5};
int (*ptr)[5] = &arr; // 正确:取整个数组的地址
此时ptr指向整个数组arr,而*ptr就是数组本身,可以通过(*ptr)[i]访问第i个元素:
cout cout
实际应用场景
数组指针常用于多维数组处理或函数参数传递。例如,二维数组本质上可看作一维数组的数组:
int matrix[3][4];
int (*pmat)[4] = matrix; // 指向包含4个int的数组,可遍历每一行
也可用于函数中避免数组退化:
void process(int (*arr)[10]) {
// 可以知道数组大小,sizeof(*arr) == 10 * sizeof(int)
}
基本上就这些。数组指针的关键是理解它指向的是“整个数组”,而非单个元素,因此类型必须匹配数组的维度和大小。使用时注意加括号,确保优先级正确。不复杂但容易忽略细节。
评论(已关闭)
评论已关闭