数组到指针衰减并将多维数组传递给函数
我知道一个数组衰减到一个指针,如果一个声明
char things[8]; 然后在以后的东西在别的地方,事情是指向数组中第一个元素的指针. 另外,从我的理解,如果一个声明 char moreThings[8][8]; 那么moreThings不是指向char的类型指针,而是类型“指向char的指针数组”,因为衰减只发生一次. 当更多的东西被传递给一个函数(使用原型void doThings(char thingsGoHere [8] [8]))堆栈中实际发生了什么? 如果moreThings不是指针类型,那么这真的还是一个pass-by-reference吗?我想我一直认为moreThings仍然代表多维数组的基地址.如果doThings采取了输入的东西,如果它本身将它传递给另一个函数呢? 这是规则,除非将数组输入指定为const,否则数组将始终是可修改的? 我知道类型检查的东西只发生在编译的时候,但是我仍然感到困惑的是技术上被称为通过引用(即仅当类型指针的参数被传递,或者指针数组是通过的时候)副参考?) 对不起,有这个问题的地方有一点,但由于我难以理解这一点,很难说明一个精确的询问. 解决方法
你有点错误:moreThings也衰减到第一个元素的指针,但由于它是一个数组的字符数组,第一个元素是一个“8个字符的数组”.所以衰减的指针是这样的:
char (*p)[8] = moreThings; 指针的值当然与& moreThings [0] [0]的值相同,即第一个元素的第一个元素的值,并且与& a相同,但该类型是不同的在每种情况下 这里是一个例子,如果char a [N] [3]: +===========================+===========================+==== |+--------+--------+-------+|+--------+--------+-------+| || a[0,0] | a[0,1] | a[0,2]||| a[1,0] | a[1,1] | a[1,2]|| ... |+--------+--------+-------+++--------+--------+-------++ ... | a[0] | a[1] | +===========================+===========================+==== a ^^^ ||+-- &a[0,0] |+-----&a[0] +-------&a >& a:char数组的整个数组的地址,这是一个char [N] [3] 这表明不同的对象可能具有相同的地址,但如果两个对象具有相同的地址和相同的类型,则它们是相同的对象. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |