数组与指针区别和联系

来源:互联网 发布:手机数据可以恢复吗 编辑:程序博客网 时间:2024/06/05 21:17

1.

在函数中数组退化为指针

int ar[]={12,23,34,45,56,67,78,89,90,100};int n=sizeof(ar)/sizeof(ar[0]);ar[0]=100;//*(ar+0)=100for(int i=0;i<n;i++)    {    printf("%d %d %d \n", ar[i] ,*(ar+i),i[ar]);    }           //  =>* (ar+i), * (ar+i) , * (i+ar)                // 输出三列相同的值int *p=ar;      //正确  ==int *p=&ar[0]                //ar 是整形指针                //*(p+1)=>p[1]  for(int i=0;i<n;i++)printf("%d %d",ar[i],p[i]);//=>* (ar+i) , * (p+i)

2.

ar [ ]={ };
int * p=ar;
&ar =>首元素地址
&p =>指针地址

3.

ar++;//(错误)数组不能自加和赋值
p++;//指针可以

4.

int ar[10]={12,23,34,45,56,67,78,89,90,100};
int * p=ar;
siezof(ar)=>40,数组的大小由数组元素个数和类型决定
sizeof(p)=>4 , 指针的大小永远为4

5.

数组指针(也称行指针)
定义 int (*p)[n];
( )优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n。也就是说执行p+1时,p要跨过n个整型数据的长度。
数组指针只是一个指针变量,似乎是C语言里专门用来指向二维数组的,它占有内存中一个指针的存储空间。
指针数组
定义 int *p[n];
[]优先级高,先与p结合成为一个数组,再由int* 说明这是一个整型指针数组,它有n个指针类型的数组元素。这里执行p+1是错误的,这样赋值也是错误的:p=a;因为p是个不可知的表示,只存在p[0]、p[1]、p[2]…p[n-1],而且它们分别是指针变量可以用来存放变量地址。但可以这样 * p=a; 这里*p表示指针数组第一个元素的值,a的首地址的值。
指针数组是多个指针变量,以数组形式存在内存当中,占有多个指针的存储空间。