C++指针偏移原理

本文介绍了C++中如何使用指针遍历整型数组,通过示例代码展示了指针如何通过地址偏移访问数组元素。指针在初始化为数组首地址后,每次增加一个int数据大小的偏移量即可依次访问每个元素。这种机制适用于不同类型的数组,只需调整偏移量为相应类型的数据大小。
摘要由CSDN通过智能技术生成

        在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,若为其它类型数据则只需偏移该类型的内存大小即可。        

        我们可以得出结论对于一个指针其遍历数据时,是通过数据与头地址的偏移量来获取的,而不是变量名。

 

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值