时间:2021-05-20
关于二维数组中数组元素的存储地址,有同学问出了个好问题。
在我的课件中,出现了下面的讲解:
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++的价值,可见主动寻疑验证的价值。
想起离散数学中的代数结构,用符号任意地表达运算,研究或设计运算系统,好一个“让思绪飞扬”和”精彩世界“,一不留神却成了“枯燥乏味”和“与实践无关”。
能从不同层面,不同视角看问题,这就是自由。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C++中指针指向二维数组实例详解一维指针通常用指针表示,其指向的地址是数组第一元素所在的内存地址,如下intary[4][5];int(*aryp)[5]=ar
C/C++动态数组的创建的实例详解在C++语言中,二维动态数组主要使用指针的方法建立,以建立一个整数二维数组为例:#include#include#includ
ios开发基础之二维数组详解首先我们知道oc中是没有二维数组的,二维数组是通过一位数组的嵌套实现的,但是别忘了我们有字面量,实际上可以和c/c++类似的简洁地创
二维数组遍历:思想:1.先将二维数组中所有的元素拿到2.再将二维数组中每个元素进行遍历,相当于就是在遍历一个一维数组第一种方法:双重for循环//遍历二维数组p
本文实例讲述了Java二维数组。分享给大家供大家参考,具体如下:一点睛1每行的元素个数不同的二维数组Java定义二维数组更加灵活,允许二维数组中的每行的元素个数