C语言定义数组指针的三种方法 C语言中有一种语法叫做数组指针,就是使用一个指针变量指向一个数组,然后对数组进行访问操作.
下面给出代码示例定义的方法, 代码如下:
#include<stdio.h>int main(){ //定义数组指针的第一种方法 { printf("=====================================n"); int (*p)[5] = NULL; int arr[5] = {1,2,4,5,7}; p = &arr; int num = sizeof(arr)/sizeof(arr[0]); for(int i = 0; i < num; i ++){ //printf("%dn",*p[i]); //printf("%dn",p[i]); printf("%dn",(*p)[i]); } } //定义数组指针的第二种方法 { printf("=====================================n"); typedef int (typeArray)[5]; int arr[5] = {4,6,8,0,1}; typeArray *p = NULL; p = &arr; int num = sizeof(arr)/sizeof(arr[0]); for(int i = 0; i < num; i++){ printf("%dn",(*p)[i]); } } //定义数组指针的第三种方法 { printf("=====================================n"); typedef int (*typeArray)[5]; int arr[5] = {4,6,8,0,1}; typeArray p = NULL; p = &arr; int num = sizeof(arr)/sizeof(arr[0]); for(int i = 0; i < num; i++){ printf("%dn",(*p)[i]); } } return 0;}
我们通过上面的代码可知, 这三种方式通过数组指针来访问数组元素——-(*p)[i]
如果printf(“%dn”,p[i]) 那么打印的是数组的首元素地址 ,接下来也是地址—–该数组的首地址加上该数组的长度,………. .例如:该数组的元素首地址是10000那么,接下来的地址是10020, 10040,10060…….
因为进行了p=&arr的赋值,而&arr代表整个数组的赋值
那么打印语句printf(“%dn”,*p[i])打印的是上面所说地址的内容.即10000,10020,10040…… 处的内容