我有一个关于C/C++如何在内部存储使用符号声明的多维数组的问题foo[m][n]
.我不是在质疑指针的纯指针等等......因为速度原因,我在问...
如果我错了,请纠正我,但语法上foo
是一个指针数组,它们本身指向一个数组
int foo[5][4]
*(foo + i) // returns a memory address
*( *(foo + i) + j) // returns an int
Run Code Online (Sandbox Code Playgroud)
我从很多地方听说过C/C++编译器foo[m][n]
在幕后转换为一维数组(计算所需的一维索引i * width + j
).但是如果这是真的那么以下就可以了
*(foo + 1) // should return element foo[0][1]
Run Code Online (Sandbox Code Playgroud)
因此我的问题foo[m][n]
是:(总是吗?)存储在内存中作为平面一维数组是真的吗?如果是这样,为什么上面的代码如图所示.
如果我以下列方式浏览2D数组的元素,它是不确定的行为吗?
int v[5][5], i;
for (i = 0; i < 5*5; ++i) {
v[i] = i;
}
Run Code Online (Sandbox Code Playgroud)
然后,它甚至编译?(我现在不能尝试,我不在家.)如果没有,那么想象我以某种方式获得了指向第一个元素并使用taht代替的指针v[i]
.