对于C++中二维数组的地址的理解

首先,我自己犯的最多的错误不在于对二维数组(python里面ndarray的理解类似),可以看成由两个一维数组迭代出来的结果,主要区分运用
int*p[3] 与int (*p)[3];

这两个中对于二维数组比较常用的是 int (p)[3]=a (其中a已经定义为34的二维数组)
实例上来看:
int main()
{
int a[3][4] = { 0,1,2,3,4,5,6,7,8,9,10,11 };
*int (p)[4]; p = a;
//观察每个p+1的变化
cout << “看二维数组第一次迭代的数组地址” << endl;
cout << p <<’ '<< (p + 1) << endl;
cout << “看二维数组真正的数组地址对应值” << endl;
cout <<"首位元素: "<< **p << endl <<"第2行第3列: "<<
(
(p+1)+2)<<endl <<"看第3行第2列: " << ((p+2)+1) << endl;
system(“pause”);
return 0;
}
在这里插入图片描述
结果表明,p与*p都代表着数组名,即当前数组的首地址,再对其迭代这进行运算。

在这里插入图片描述
而这里的题目提醒我,任何一个元素数组都是像一维数组一样按顺序依次就行存储,就像链表一样的
int main()
{
int a[3][4] = { 0,1,2,3,4,5,6,7,8,9,10,11 };
int(p)[4]; p = a; int tmp = &a[0][0];
//观察每个p+1的变化
cout << “看二维数组第一次迭代的数组地址” << endl;
cout << p <<’ '<< (p + 1) << endl;
cout << “看二维数组真正的数组地址对应值” << endl;
cout <<"首位元素: "<< **p << endl <<"第2行第3列: "<<
(
(p+1)+2)<<endl <<"看第3行第2列: " << ((p+2)+1) << endl;
cout << endl;
cout << "第2行第3列元素: "<<
(
(p + 1) + 2) <<" "<<(tmp+41+2)<< endl;
system(“pause”);
return 0;
}
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值