数组传参是将数组首元素的地址传递给函数,函数在内部创建一个指针变量来接收
void print(int arr[])
int arr[];
print(arr);
viod print内部的arr即arr数组首元素地址,int表示数组内部元素的类型
int a [10];
int b [10];
int * c;
c= &a[0];
c = a;
数组名表示的并非整个数组,如果是那样c = a表示将整个数组复制到一个新的数组,但这样做是无效的传参,实际被赋值的是一个指针的拷贝。因此可以通过下标和指针两种方式在函数内部访问数组元素。
void test1(int* arr[3]){}
void test2(int** arr){}
int arr[][3] = {0, 1, 2, 3, 4, 5};
test(arr);
test1和test2两种写法都是可行的传参,二级指针意为通过函数通过指针访问一维数组首元素地址集合的指针数组。
int main()
{
int a[5] = {5, 4, 3, 2, 1};
int *ptr = (int *)(&a + 1);
printf( "%d,%d", *(a + 1), *(ptr - 1));
return 0;
}
&a的类型为int(*)[5],即是数组指针,其长度是数组的长度。&a是数组首元素的地址,强制类型转化为(int *),即为整形指针。