[问题] 2D 阵列之内存位址有移位情形

楼主: gowrite (gowrite)   2021-05-02 07:10:22
开发平台(Platform): (Ex: Win10, Linux, ...)
GNU/Linux
编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
GCC
额外使用到的函数库(Library Used): (Ex: OpenGL, ...)
N/A
问题(Question):
印象中,
阵列不管是几维的,内存位址应该是连续分布,
但实际上有规则性跳跃的情况
想问各位,这样的行为有专有名词吗?
谢谢
喂入的资料(Input):
请看下方程式码
预期的正确结果(Expected Output):
预期 二维阵列 在 row 0 到 row 1 时,
内存的位址也是连续,
但实际上展现出来是会跳跃 找 0 尾数为 下一个 row 的开头
错误结果(Wrong Output):
无错误,想知道是编译器的问题,还是 C 语言的正常规格行为
程式码(Code):(请善用置底文网页, 记得排版,禁止使用图档)
int row = 2;
int col = 3;
// 建立 二维 int 阵列
int **arr = malloc(sizeof(int *) * row);
for(int i=0 ; i<row ; i++){
arr[i] = malloc(sizeof(int) * col);
}
// 填入数值
for(int i=0 ; i<row ; i++){
for(int j=0 ; j<col ; j++){
arr[i][j] = i+ ((j+1)*2);
}
}
当 row = 2, col = 3 时
row :0, col :0, arr[0][0] = 2, 0x55963ccf92c0
row :0, col :1, arr[0][1] = 4, 0x55963ccf92c4
row :0, col :2, arr[0][2] = 6, 0x55963ccf92c8
row :1, col :0, arr[1][0] = 3, 0x55963ccf92e0
row :1, col :1, arr[1][1] = 5, 0x55963ccf92e4
row :1, col :2, arr[1][2] = 7, 0x55963ccf92e8
可以看到 row 1 跟 row 2 中间从 92c8 跳到了 92e0 多跳了 4 bytes
当 row = 2, col = 4 时
row :0, col :0, arr[0][0] = 2, 0x55b7ab0542c0
row :0, col :1, arr[0][1] = 4, 0x55b7ab0542c4
row :0, col :2, arr[0][2] = 6, 0x55b7ab0542c8
row :0, col :3, arr[0][3] = 8, 0x55b7ab0542cc
row :1, col :0, arr[1][0] = 3, 0x55b7ab0542e0
row :1, col :1, arr[1][1] = 5, 0x55b7ab0542e4
row :1, col :2, arr[1][2] = 7, 0x55b7ab0542e8
row :1, col :3, arr[1][3] = 9, 0x55b7ab0542ec
这样就正常
当 row = 2, col = 5 时
row :0, col :0, arr[0][0] = 2, 0x55eea8bac2c0
row :0, col :1, arr[0][1] = 4, 0x55eea8bac2c4
row :0, col :2, arr[0][2] = 6, 0x55eea8bac2c8
row :0, col :3, arr[0][3] = 8, 0x55eea8bac2cc
row :0, col :4, arr[0][4] = 10, 0x55eea8bac2d0
row :1, col :0, arr[1][0] = 3, 0x55eea8bac2e0
row :1, col :1, arr[1][1] = 5, 0x55eea8bac2e4
row :1, col :2, arr[1][2] = 7, 0x55eea8bac2e8
row :1, col :3, arr[1][3] = 9, 0x55eea8bac2ec
row :1, col :4, arr[1][4] = 11, 0x55eea8bac2f0
居然从 c2d0 多跳了 12 个 bytes 硬是跳到 c2e0 开头
补充说明(Supplement):
N/A
作者: LPH66 (-6.2598534e+18f)   2021-05-02 07:44:00
因为你并不是为底层结构配置连续内存 (你的 for/malloc)也就是说, 对系统来说你的每一列都是个别一块内存因此它们之间就并不一定有什么位置上的关系了会在附近只是因为刚好那附近都还没人用而已要配置成连续的也不是不行, 但就不是 for/malloc 一列一列要, 而是一口气要来一整块之后指定每一列进列指标阵列另外, cc 到 e0 没有连续喔, 中间还有 d
作者: F04E (Fujitsu)   2021-05-02 08:29:00
你是配置了复数个一维阵列而不是一个二维...
作者: stupid0319 (征女友)   2021-05-02 09:25:00
malloc二维阵列应该是for loop malloc多个一维阵列编译器没问题,C语言也没问题,单纯只是写法bug写code怀疑编译器有问题的,我是头一个看到.........
作者: xam (听说)   2021-05-02 12:11:00
code写错,怀疑编译器/程式语言/电脑有错的人,很多啊
作者: millaker0820 (Millaker)   2021-05-02 17:48:00
正确写法应该是先malloc一个大小为row*col的连续内存,在一一把pointer指向每个row的开头 这样就会是连续的了
作者: Lipraxde (Lipraxde)   2021-05-02 21:19:00
很有想法 !
作者: cuteSquirrel (松鼠)   2021-05-03 10:29:00
一楼专业
作者: chchwy (mat)   2021-05-03 11:17:00
你呼叫了好多次malloc() 这样当然没有保证连续
作者: Qbsuran (Qbsuran)   2021-05-04 18:26:00
就算是一次分配 阵列只有1D/2D "刚好"连续

Links booklink

Contact Us: admin [ a t ] ucptt.com