目录:
1.指针与一维数组
2.指针与二维数组
3.指针数组与数组指针
当定义一个一维数组时,系统会在内存中为改数组分配一个储存空间,其数组的变量名就是数组的首地址。若定义一个指针变量,并将数组的首地址赋值给指针变量,则我们说该指针指向了这个一维数组。
例如:
另一种赋值方式也可写为:
上述两种赋值方式是一样的。p+n与a+n表示数组元素a[n]的地址,即&a[n]。对于a数组来说,有10个元素,n的取值就为0~9,则数组的地址就可以表示为p+0 ~p+9或者a+0 ~a+9。也就是说*(p+n)和*(a+n)表示数组的元素 。
此外,指针的移动也可以用++,–来表示。即*p++,a++。
这里我们在一维数组的基础上进一步了解指针与二维数组。我们定义一个3行5列的二维数组a[3][5]。
我们详细了解讨论二维数组的内容。
1.&a[0][0]可以表示数组0行0列的首地址,同时也可以看作是二维数组的首地址。&a[n][m]表示第m行n列元素的地址。
2.a,a+1,a+2分别代表第一,第二,第三行的首地址(a[0],a[1],a[2]也可以代表首地址),其中a也是二维数组的首地址。
3.a[0]+m表示第0行第m个元素地址,比如a[1]+1代表的第二行第二列的地址。
4.p+n表示移动到n个内存单元。
ps
这里介绍一下如何通过指针来引用二维数组:一种为 * ( * (a+n)+m) 表示第n行第m列元素;另一种为 *(a[n]+m)。这里要注意,利用使用二维数组地址时,*(a+i)与a[i]与a+1是等价的,都是首地址。可能有同学会奇怪,可能认为 * (a+i)与a+1不应该等价呀,a+1是地址,那 *(a+i)应该是该地址上储存的内容呀。对于这个问题,因为二维数组比较特殊,不像一维数组,所以这个地方特别注意一下就行。
3.1数组指针(也称为行指针)
定义为:int( * p)[n]; (注意优先级:()>[]> *)(int (*p)[5]定义了一个指向含有5个元素的一维数组的指针。)
当数组指针指向一个一维数组时:
()优先级高,说明p是指针,指向一个整型的一维数组。这个一维数组的长度是n,也可以说p的步长为n。当p+1时,p指针会跨过n个整型数据的长度。
当数组指针指向一个二维数组时:
所以,数组指针也成为指向一维数组的指针,也就是行指针。
3.2指针数组
定义为:int* p[n]; (注意优先级:()>[]> *)
[]> * ,所以p是数组,是一个由n个指针类型元素组成的指针数组,或者说这个当一个数组里含有的元素为指针类型的时候,它就被成为指针数组。当p+1时,则p指向下一个数组元素。(需注意,p=a;这种赋值方法是错的,因为p是一个不可知变量,只存在p[0],p[1],p[2],但可以这样 p=a; 这里p表示指针数组第一个元素的值,a的首地址的值)
将二维数组赋值给指针数组:
版权声明:
本文来源网络,所有图片文章版权属于原作者,如有侵权,联系删除。
本文网址:https://www.mushiming.com/mjsbk/4334.html