您可以先跳过本章,等了解了 C++ 指针的概念之后,再来学习本章的内容。
如果您对 C++ 指针的概念有所了解,那么就可以开始本章的学习。数组名是指向数组中第一个元素的常量指针。因此,在下面的声明中:
double runoopsAarray[50];
runoopsAarray 是一个指向 &runoopsAarray[0] 的指针,即数组 runoopsAarray的第一个元素的地址。因此,下面的程序片段把 p 赋值为 runoopsAarray 的第一个元素的地址:
double *p; double runoopsAarray[10]; p = runoopsAarray;
使用数组名作为常量指针是合法的,反之亦然。因此,*(runoopsAarray+ 4) 是一种访问 runoopsAarray[4] 数据的合法方式。
一旦您把第一个元素的地址存储在 p 中,您就可以使用 *p、*(p+1)、*(p+2) 等来访问数组元素。下面的实例演示了上面讨论到的这些概念:
实例
#include <iostream>
using namespace std;
int main ()
{
// 带有 5 个元素的双精度浮点型数组
double runoopsAarray[5] = {1000.0, 2.0, 3.4, 17.0, 50.0};
double *p;
p = runoopsAarray;
// 输出数组中每个元素的值
cout << "使用指针的数组值 " << endl;
for ( int i = 0; i < 5; i++ )
{
cout << "*(p + " << i << ") : ";
cout << *(p + i) << endl;
}
cout << "使用 runoopsAarray 作为地址的数组值 " << endl;
for ( int i = 0; i < 5; i++ )
{
cout << "*(runoopsAarray + " << i << ") : ";
cout << *(runoopsAarray + i) << endl;
}
return 0;
}
当上面的代码被编译和执行时,它会产生下列结果:
使用指针的数组值
*(p + 0) : 1000
*(p + 1) : 2
*(p + 2) : 3.4
*(p + 3) : 17
*(p + 4) : 50
使用 runoopsAarray 作为地址的数组值
*(runoopsAarray + 0) : 1000
*(runoopsAarray + 1) : 2
*(runoopsAarray + 2) : 3.4
*(runoopsAarray + 3) : 17
*(runoopsAarray + 4) : 50
在上面的实例中,p 是一个指向 double 型的指针,这意味着它可以存储一个 double 类型的变量。一旦我们有了 p 中的地址,*p 将给出存储在 p 中相应地址的值,正如上面实例中所演示的。
C++ 中,将 char * 或 char[] 传递给 cout 进行输出,结果会是整个字符串,如果想要获得字符串的地址(第一个字符的内存地址),可使用以下方法:
强制转化为其他指针(非 char*)。可以是 void *,int *,float *, double * 等。* 使用 &s[0] 不能输出 s[0](首字符)的地址。因为 &s[0] 将返回 char*,对于 char*(char 指针),cout 会将其作为字符串来处理,向下查找字符并输出直到字符结束 *。
实例
#include <iostream>
using namespace std;
const int MAX = 3;
int main ()
{
char var[MAX] = {'a', 'b', 'c'};
char *ptr;
// 指针中的数组地址
ptr = var;
for (int i = 0; i < MAX; i++)
{
cout << "Address of var[" << i << "] = ";
cout << (int *)ptr << endl;
cout << "Value of var[" << i << "] = ";
cout << *ptr << endl;
// 移动到下一个位置
ptr++;
}
return 0;
}
输出结果:
Address of var[0] = 0x61fe11 Value of var[0] = a Address of var[1] = 0x61fe12 Value of var[1] = b Address of var[2] = 0x61fe13 Value of var[2] = c