1.指针操作数组快于下标操作数组
2.数组的空间分配.如int a[10];——会在空间分配出40个相邻的内存单元来(10*4)。
注意事项:
a、数组不可以进行++ar运算;也不可以ar=NULL;//数组名退化成指针后,不可以++ar和赋值操作,因为退化后ar为常量值,代表首元素的地址
b、&ar指整个数组的地址,&ar+1则指的是下一个数组的首地址。
3.指针操作数组
int *pa;
pa = &a[0];
4.指针移动
int *pa;
int a[10];
pa = &a[0];
pa+1 等于是指向第5个内存单元——a[1]的第一个内存单元。
注意事项:
&p是指针地址,&p+1会根据指针指定的类型int移动4个内存单元,1的大小是取决于pa的类型int的,指针类型决定指针跨内存单元的步长。
5.规则:
>> &ar[i]和ar+i含义相同,相互使用。ar+i是ar之后第i个元素地址。
>> 数组名代表数组第一个元素的地址。
6.指针相减:
int ar[10]={12,23,34,45,56,67,78,89,90};
int *p1=&ar[0];
int *p2=&ar[4];
int len=p2-p1;//两个指针相减,表示俩个指针之间隔了多少个元素;
指针相减特点:
(1)、两个指针间的类型相同;(2)、算头不算尾,即元素个数为p2-p1+1;(3)、(p2-p1)/2+p1;//求p1和p2中间的指针;
注意:两个指针之间只能进行相减,不能进行相加。