指针变量既然可以指向变量,当然也可以指向数组元素(把某一元素的地址放到一个指针变量中),所谓数组元素的指针就是数组元素的地址。
int a[10];
int *p;
p=&a[0]; //把a[0]元素的地址赋给指针变量p,也就是使p指向数组a的第0个元素。
p=a; //与上一句等价,C语言规定数组名代表数组中首元素的地址。
注意:
(1)p+i和a+i就是a[i]的地址, 即实际地址的计算方法为a+i*d,因为为int型,所以d=2.
(2)*(p+i)或*(a+i)是p+i或a+i所指向的元素,即a[i]
(3)指向数组的指针变量也可以带下标,如p[i]与*(p+i)等价
所以,引用一个元素,可以用
1、下标法,如a[i]
2、指针法,如*(a+i)或*(p+i)
在使用指针变量指向数组元素时,需要注意以下几个问题:
(1)可以通过改变指针变量的值指向不同的元素,eg:p++,这是可以的
(2)要注意指针变量的当前值
(3)上面的例子中数组的大小为10,但是实际上指针变量p可以指向数组以后的内存单元。
(4)注意指针变量的运算(p=a)
i、p++,使p指向下一个元素,即a[1],若再执行*p,则得到a[1]的值
ii、*p++,由于*和++同一个优先级,结合方向为自右向左,因此等价于*(p++),作用是先得到*p,再使p+1
用数组名做函数参数
void main(){
void f(int arr[],int n);
int array[10];
f(array,10); //实参
}
void f(int arr[],int n) //形参
{
.............
}
实参数组名代表的是该数组首元素的地址,而形参是用来接收从实参传递过来的数组首元素的地址,因此,形参应该是一个指针变量。
因为只有指针变量才能存放地址。实际上,C编译都是将形参数组名作为指针变量来理解的
所以 f(int arr[],int n)和f(int *arr,int n)是等价的,在编译时,将arr按指针变量处理。
sizeof(arr)=2,整型指针为2个字节,是按指针变量进行处理的。
当arr接收了实参数组的首元素地址后,arr就指向实参数组的首元素。也就是array[0]
注意:当用变量名作为函数参数时传递的是变量的值,
当用数组名作为函数参数时,由于数组名代表的是数组首元素的地址,所以传递的是地址。
因此形参数组和实参数组共占同一段内存,在调用函数期间,如果改变了形参数组的值,也就是改变了实参数组的值。