数组指针指向的是数组,数组指针中存放的应该是数组的地址。
int main(){
int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };
int(*p)[10] = &arr;
system("pause");
return 0;
}
数组指针是 指向数组的指针,所以把数组的地址赋给指针,让指针指向这个数组,但是一般很少写这样的代码
一般用数组指针使用如下:
void ptintf_arr1(int arr[3][5], int row, int col){
for (int i = 0; i < row; ++i){
for (int j = 0; j < col; ++j){
printf("%d ", arr[i][j]);
}
putchar('\n');
}
}
void printf_arr2(int(*arr)[5], int row, int col){
for (int i = 0; i < row; ++i){
for (int j = 0; j < col; ++j){
printf("%d ", arr[i][j]);
}
putchar('\n');
}
}
int main(){
int arr[3][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 0 };
ptintf_arr1(arr, 3, 5);
//数组名arr,表示首元素的地址
//但是二维数组的首元素是二维数组的第一行
//所以这里传递的arr,其实相当于第一行的地址,是一维数组的地址
//可以数组指针来接收
printf_arr2(arr, 3, 5);
system("pause");
return 0;
}