优先级:()>[]>*
指针数组
本质还是一个数组
定义:int *p[n];
[]优先级高,先与p结合成为一个数组,再由int*说明这是一个整型指针数组,它有n个指针类型的数组元素。
如将二维数组赋给一个指针数组:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int arr[3][4] = { {1,2,3,4},{5,6,7,8},{9,10,11,12} }; //定义二维数组
int* p[3]; //定义一个指针数组,指向含有四个元素的一维数组
for (int i = 0; i < 3; i++) //赋值
{
p[i] = arr[i];
}
for (int i = 0; i < 3; i++) //通过指针数组打印
{
for (int j = 0; j < 4; j++)
{
printf("%d ",*(*(p+i)+j));
}
printf("\n");
}
system("pause");
return 0;
}
这里int *p[3] 表示一个一维数组内存放着三个指针变量,分别是p[0]、p[1]、p[2],所以要分别赋值。
*(p[i]+j)、*(*(p+i)+j)、(*(p+i))[j]、p[i][j]表示数组中第i行j列的元素。
数组指针(也称行指针)
定义 int (*p)[n];
()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
如要将二维数组赋给一指针,应这样赋值:
#include<stdio.h>
#include<stdlib.h>
int main()
{
int arr[3][4] = { {1,100,3,4},{5,6,7,8},{9,10,11,12} };
int(*p)[4];
p = arr; //将该二维数组的首地址赋给p,也就是a[0]或&a[0][0]
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 4; j++)
{
printf("%d ",*(*(p+i)+j));
}
printf("\n");
}
system("pause");
return 0;
}
所以数组指针也称指向一维数组的指针,亦称行指针
区别
指针数组:首先它是一个数组,数组的元素都是指针,数组占多少个字节由数组本身的大小决定,每一个元素都是一个指针,是“储存指针的数组”的简称。
数组指针:首先它是一个指针,它指向一个数组。是“指向数组的指针”的简称。
练习1
int* p[10]; 指针数组;
int (*p2)[10]; 是数组指针;
int* p[10];
int (*p)[10];
int *p[10];
int (*p[10])[5];
练习2