在C++中我们可以通过指针方便的访问各种类型数据,但我们都知道指针只是一个头地址,而我们需要遍历的数据通常占有大量的空间,那么指针是如何遍历其中的数据呢?这就涉及到指针偏移的一个问题,下面我们看个例子:
这里使用了十进制显示地址函数ip2decimal(),详情见“C++显示十进制内存地址”。
int a[4]={1,2,3,4};
int* p=&a[0];//将数组a的初始地址传给指针p
cout<<"指针p的地址:"<<ip2decimal(p)<<endl;
cout<<"a的地址分别为:"<<endl;
for (int i = 0; i < 4; i++)
{
cout<<ip2decimal(&a[i])<<endl;
}
for (int i = 1; i < 5; i++)
{
cout<<"p地址为:"<<ip2decimal(p)<<"\t数值为:"<<*p<<endl;
p=p+1; //指针增加一个int的偏移量
}
结果为:
通过上述结果我们可以发现,对于一个存储多个数据的int数组,我们可以通过设定个int* p的指针,只需将数组头指针赋给指针p,便可以通过指针p每次增加一个int数据的偏移量准确获取每个int类型数据。这里int数据的偏移量为4,若为其它类型数据则只需偏移该类型的内存大小即可。
我们可以得出结论对于一个指针其遍历数据时,是通过数据与头地址的偏移量来获取的,而不是变量名。