当上面的代码被编译和执行时,它会产生下列结果:
Value of var[0] = 10 Value of var[1] = 100 Value of var[2] = 200可能有一种情况,我们想要让数组存储指向 int 或 char 或其他数据类型的指针。下面是一个指向整数的指针数组的声明:
int *ptr[MAX];在这里,把 ptr 声明为一个数组,由 MAX 个整数指针组成。因此,ptr 中的每个元素,都是一个指向 int 值的指针。下面的实例用到了三个整数,它们将存储在一个指针数组中,如下所示:
当上面的代码被编译和执行时,它会产生下列结果:
Value of var[0] = 10 Value of var[1] = 100 Value of var[2] = 200您也可以用一个指向字符的指针数组来存储一个字符串列表,如下:
当上面的代码被编译和执行时,它会产生下列结果:
Value of names[0] = Zara Ali Value of names[1] = Hina Ali Value of names[2] = Nuha Ali Value of names[3] = Sara Ali其次,”数组”修饰这个指针,意思是说这个指针存放着一个数组的首地址,或者说这个指针指向一个数组的首地址。
根据上面的解释,可以了解到指针数组和数组指针的区别,因为二者根本就是种类型的变量。
Tibbers
226***1148@qq.com
maxxu
550***816@qq.com
walker
lyo***h@foxmail.com
指针数组 :指针的数组,实际是一个数组,长度由数组本身决定,这个数组的所有元素都是指针类型,存放的都是地址。
int *prt[ 10 ] ; *prt[ 1 ],*prt[ 2 ],*prt[ 3 ]...... 数组中每个元素都指向一个地址。
数组指针 :数组的指针,实际是一个指针,长度固定(32 位系统下占 4 个字节),这个指针指向数组,但指向的数组占多少个字节不确定。
int a[5]={ 1,2,3,4,5 }; //定义一个一维数组 a int (*prt)[5]; // 步长为 5 的数组指针,即 prt 指向的数组里有 5 个元素 prt=&a; // 把数组 a 的地址付给 prt,则 prt 为数组 a 的地址,*prt 表示数组 a 本身 prt[ 0 ]; //表示数组首元素的地址 *prt[ 0 ]; //表示数组的首元素的值,即为数组 a 的 1 **prt; //表示数组的首元素的值,即为数组 a 的 1 *prt[ 1 ] ; //表示指向数组的下一行元素的首元素的值,但是a是一维数组,只有一行,所以指向的地址中的值不确定
数组指针加 1,步长为所指向数组的列数,即为下一行的首地址,只在二维及以上维度的数组中有意义,一维数组只有一行,无意义。
Nicole
zhe***j913@gmail.com
int *a[3] :为什么这里是指针数组, [] 的优先级高于 * ,所以这是一个数组,而 * 修饰数组,所以是指针数组,数组的元素是整型的指针。
int main() { char *str[3]; str[0] = "abc"; str[1] = "efg"; str[2] = "hij"; for (int i = 0; i < 3; ++i) { printf("%s\n", str[i]); int (*a)[3]:同样的方式,首先括号的优先级最高,所以 *a 是指针,而 [] 修饰 *a ,所以是数组指针,一个指向 3 个元素的一维数组指针。typedef int arr[3]; int main() { arr b = {1, 2, 3}; int (*a)[3] = &b; arr *c = a; for (int i = 0; i < 3; ++i) { printf("%d\n", (*a)[i]); 这里使用 typedef。我们自定义了一个数据类型,为数组数据类型。起数据类型为三个整型元素的数组。定义数组指针也有两种方式,一个是使用我们上面自定义的数组数据类型,一个是直接定义。
davidquent
159***42298@163.com