c数组和指针的理解

时间:2023-03-08 21:33:21
 #include<stdio.h>

 int main(void)
{
int a[]={,,,,};
int *p = (int*)(&a + );
printf("%d,%d\n",*a+,*(p-)); // int (*ptr1)[] = &a; √
// int (*ptr2)[] = a; ×
// int (*ptr1)[] = &a; ×
// int (*ptr2)[] = a; ×
} //2,5

数组名只可以作为右值!

当我们定义一个数组时候,编译器根据指定的元素个数和类型确定分配内存大小。并把这一块地址的名称赋为数组名称。

a[0]、a[1]......为数组元素,但并非元素名称!

指针,32系统总是为4字节(0x11111111)只能存放一个地址单元的值,所以总是存放的首地址。

但是访问时候需要根据类型大小来移动指针。

数组名:值等同于数组“首元素”的“首地址”(数组首元素的指针)

P + 1

char*移动一个字节,int*移动4个字节!数组指针移动一个数组元素类型长度!二级指针移动一个指针长度(4)!

&a:表示数组指针(取数组变量a的指针)

对数组的访问,总是转换为对指针的访问!

二维数组

 int b[][] = {{,},{,}};
// int *p2 = b; ×
// int (*p5)[2] = b; √
// int **p = b; ×

二维数组名称,指向首元素b[0]的指针,为数组指针【一级指针】!

 // int *p3 = b[0];             √
// int (*p4)[2][2] = &b; √

二维数组所有元素的访问(一级指针):

 #include<stdio.h>
int main()
{
int iArray[][] = {{,,},{,,}};
int *pArray = NULL; pArray = (int*)iArray; printf("array[0][0] = %d\n", *pArray);
printf("array[1][2] = %d\n", *(pArray + ));
printf("array[1][2] = %d\n", *(pArray + * + )); /*数组本身在地址空间中就是连续排列的*/
printf("array[1][2] = %d\n", *((int *)(*((int (*)[])pArray + )) + ));
return ;
}

二维数组所有元素的访问(数组指针):

 #include<stdio.h>

 int main()
{
int iArray[][] = {{,,},{,,}};
int (*pArray)[] = NULL; pArray = iArray; printf("array[0][0] = %d\n", **pArray);
printf("array[1][2] = %d\n", *(*(pArray+)+));
return ;
}
 int main()
{
int iArray[][] = {{,,},{,,}}; int (*pArray)[] = NULL; pArray = iArray; printf("array[0][0] = %d\n", pArray[][]);
printf("array[1][2] = %d\n", pArray[][]);
return ;
}

二级指针

为指向指针的指针,指向的值必须是指针。

 int main()
{
int iArray[][] = {{,,},{,,}};
int *ipArray[] = {iArray[], iArray[]};
int **pArray = NULL; pArray = ipArray; printf("array[0][0] = %d\n", pArray[][]);
printf("array[1][2] = %d\n", pArray[][]); return ;
}