关于数组和指针:
数组的基地址是在内存中存储数组的起始位置,它是数组中第一个元素(下标为0)的地址,因此数组名本身是一个地址,即指针值
int a[10],*p 则有p = a 和p = &a[0]等价
p = a + 1 和p = &a[1]等价
*(a+i) 和a[i]等价
*(p+i) 和p[i]等价
数组长度表示:sizeof(a)/sizeof(int)
指针变量在做p+1,p+2这样的位移运算,每+1之后移动几个字节 取决于指针变量的类型(相当于数组的角标+1)
int *p p+1之后移动4个字节
char *p p+1之后移动1个字节
例如:
void sum(int *p,int n) {
int sum = 0;
for (int i = 0; i < n;i++) {
sum = sum + *(p+i);
//或者sum = sum + p[i];
}
printf("sum = %d",sum);
}
void sum1(int a[], int n) {
int sum = 0;
for (int i = 0; i < n; i++) {
sum = sum + a[i];
//或者sum = sum + p[i];
}
printf("sum = %d", sum);
}
int main()
{
int b[10] = {1,2,3,4,6,7,9,5,2,11};
sum1(b, sizeof(b) / sizeof(int));
return 0;
}