欢迎来到代码驿站!

C代码

当前位置:首页 > 软件编程 > C代码

C++二维数组中数组元素存储地址的计算疑问讲解

时间:2021-02-26 10:52:02|栏目:C代码|点击:

关于二维数组中数组元素的存储地址,有同学问出了个好问题。

在我的课件中,出现了下面的讲解:

a[i][j]的地址是p+(i*col+j)*d(d是数组元素所占的字节数)。

同学编程序进行验证,出问题了:

地球停止转动了也必须先赞这种学习方式!

同学问:“老师,第一张图的4,我怎么觉得不对呢?第二张图我没4,结果好像也对,这里面差在哪呢?”

我的答复:“两个都对。”

第一张图在讲原理,是我们在人脑里面要以“字节”为单位计算,p为首地址,单位是字节,再往后多少个字节,必须考虑到在整型数组中每个数组元素占4个字节,从首地址到a[i][j](i*col+j)个元素,计算其字节地址时,乘4是必要的。

第二张图是在计算机中的运行结果,是已经在计算机内按找第几“个”数组元素为单位计算地址值了,*4的操作,是在寻址中已经计算过了,在此直接输出结果。

更直白地,第一张图中的“p+”中的加,和我们日常算术中的加一样,我们按“字节”说事;而第二张图中的“p+”,是C语言中指针的加运算,是增加一个单元,究竟多少字节,还要考虑指向的元素的数据类型,在32位系统中,对于整型,一个单元4字节,而对于double型,一个单元8字节。

两个加号形状一样,含义是不同。

这个问题,学C/C++的同学才可能会遇到,学习C/C++中主动寻疑验证的同学才会遇到。可见学C/C++的价值,可见主动寻疑验证的价值。

想起离散数学中的代数结构,用符号任意地表达运算,研究或设计运算系统,好一个“让思绪飞扬”和”精彩世界“,一不留神却成了“枯燥乏味”和“与实践无关”。

能从不同层面,不同视角看问题,这就是自由。

总结

上一篇:Qt绘制时钟效果

栏    目:C代码

下一篇:C++稀疏矩阵的各种基本运算并实现加法乘法

本文标题:C++二维数组中数组元素存储地址的计算疑问讲解

本文地址:http://www.codeinn.net/misctech/70240.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有