在定义一个指针的情况中,指针指向一个数组:
#include<stdio.h>
#include<stdlib.h>
int test(int *a);
int main(void)
{
int a[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 0};
test(a);
return 0;
}
int test(int *s)
{
int i;
for (i = 0; i < 10;i++)
{
s[i] = 9;
printf("%d\n", s[i]);
}
return 0;
}
在这个程序中呢是这样的,首先,在主函数里定义了数组a,然后调用函数test,函数的参数是一个指针s,(数组a和指针变量s是一样的,他们都是地址,而a[0]才是变量,所以在sanf函数中,可以scanf(“%d”,a)但不能scanf(“%d”,a[0]),因为&的是一个运算符,作用是获取变量的地址,而数组a本身就是地址(数组名是首元素的地址)所以不需要&,但在参数表中,数组scanf(“%d”,a)和scanf(“%d”,&a[0])的作用是一样的,都是将读入的整数作为变量a[0]的值,因为数组a和变量a[0]的地址是相同的。)
然后在test函数中定义了一个指针变量s,让他指向数组a或者说是指向变量a[0],而s是所指向的变量的地址,*s则是指针s所指变量上的值,s[i](对于指针变量可以,普通变量不能这么写)则可以说是,将指针s所指的地方(也就是a[0])看作一个数组s,但不同的是指针s所指的地方就会被作为s[0],然这个数组的长度就是10(如果指针s指向的是一个普通变量,那么这个数组的大小是1,如果是指向一个数组,那么数组s的大小和所指数组的大小是相同的),在用的时候一定要记得不要让下标出界,这是一个危险的做法,,即使你要输出s[11]或者如何运气好不会有什么问题,但放到其他时候就不一定了.
此时,s[0] = a[0],s[1] = a[1];如果指针变量s所指的不是a[0],也就是说调用函数test时传入的是a[1】的地址,也就是改成test(&a[1]),那么就会变成s[-1] = a[0],s[0] = a[1],s[1] = a[2].....的情况。
当指针变量指向的是一个普通变量时:
如:
.......
{
int a = 2;
int *s = &a;
return 0;
}
那么
s是一个指针变量
*s则是指针s所指的位置上的值
s[0]则是把指针s所指的地方看作是一个数组,这个数组的长度是1,那么s[0] = a[0] = 2(仅指针变量);
所以:
printf("%d",*s);
和
printf("%d",s[0]);
所输出的结果是相同的