C语言 数组指针
2019-09-09
3
0
假设您对C中的指针有一些了解,让我们开始:数组名称是指向数组的第一个元素的常量指针。
double balance[50];
Balance是指向&Balance[0]的指针,它是数组Balance的第一个元素的地址,因此,以下程序片段将p分配为Balance-的第一个元素的地址
double *p;
double balance[10];
p=balance;
将数组名称用作常量指针是合法的,反之亦然。因此,*(Balance+4)是访问Balance[4]数据的合法方式。
一旦将第一个元素的地址存储在‘p’中,就可以使用p,(p+1),*(p+2)等访问数组元素,下面给出的示例显示了上面讨论的所有概念-
#include <stdio.h>
int main () {
/* an array with 5 elements */
double balance[5]={1000.0, 2.0, 3.4, 17.0, 50.0};
double *p;
int i;
p=balance;
/* output each array element's value */
printf( "Array values using pointer\n");
for ( i=0; i < 5; i++ ) {
printf("*(p + %d) : %f\n", i, *(p + i) );
}
printf( "Array values using balance as address\n");
for ( i=0; i < 5; i++ ) {
printf("*(balance + %d) : %f\n", i, *(balance + i) );
}
return 0;
}
编译并执行上述代码时,将生成以下结果-
Array values using pointer
*(p + 0) : 1000.000000
*(p + 1) : 2.000000
*(p + 2) : 3.400000
*(p + 3) : 17.000000
*(p + 4) : 50.000000
Array values using balance as address
*(balance + 0) : 1000.000000
*(balance + 1) : 2.000000
*(balance + 2) : 3.400000
*(balance + 3) : 17.000000
*(balance + 4) : 50.000000
在上面的例子中,p是一个指向double的指针,这意味着它可以存储double类型变量的地址。一旦我们有了p中的地址,*p将为我们提供存储在p中的地址的可用值,如我们在上面的示例中所示。