指针数组和数组指针
• 数组指针(也称为 行指针) 定义: 指向一维数组的指针。 int (*p)[n]; // 重点是数组 ()优先级高,首先P是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长,即执行p+1的时候,p 要跨过n个整型数据的长度。 如将二维数组赋给一指针,可以这样: int a[3][4]; int (*p)[4]; //该语句是定义一个数组指针,指向含有4个元素的一维数组 p = a ; //将该二维数组的首地址赋给p, 也就是a[0] 或者 &a[0][0] p++; //该语句执行后,p跨过了行a[0][] 指向了 a[1][] 指针数组 定义: int *p[n]; []优先级高, 先与p结合成为一个数组,再有 int* 说明这是一个整型指针数组,它有n个指针类型的数组元素, 大专栏 指针数组和数组指针 在这里执行p+1是错误的, p = a 这样的赋值也是错误的, 因为p是个不可知的表示, 只存在p[0]、p[1]、p[2]、….p[n-1], 并且他们分别是指针变量可以用来存放变量地址。 *p = a //这里*p表示指针数组第一个元素的值,a的首地址的值。 如果要将二维数组赋值给一 指针数组: int *p[3]; int a[3][4]; for(int i = 0; i < 3; i++) { p[i] = a[i] } 这里的 int