动态申请的二维数组不是连续的
创始人
2024-11-15 16:40:57

在初学阶段,曾学过二维数组的内存空间是连续分布的,参考下图:

后来由于动态申请二维数组的方法不常用(一般都是用vector或者直接定义一个二维数组),所以就一直以为二维数组的内存空间是连续的。但实际上,只有非动态申请的二维数组的内存空间是连续的,动态申请的二维数组是不连续的!

这是因为,动态申请一个二维数组的流程一般是,先 new/malloc 出二维数组的行,然后在一个循环内再分别 new/malloc 出每一列的内容。例如:

int **arr = new int*[3]; // 先new出行 // 再循环new出列中的内容 for(int i = 0; i < 3; i++) {     arr[i] = new int[2]{i, i+1}; }

所以动态申请的二维数组,其行之间是连续的,而列之内也是连续的,但每一个列之间却是不连续的,具体参考下图:

相关内容

热门资讯

裸辞做“一人公司”,我后悔了 去年这个时候,一位以色列程序员正在东南亚旅行。他顺手把一个在脑子里转了很久的想法做成了产品,一个让任...
南京建成国内首个Pre-6G试... 4月21日,2026全球6G技术与产业生态大会在南京开幕。全息互动技术展台前,一名远在北京的工作人员...
超梵求职受邀参加“2025抖音... 超梵求职受邀参加“2025抖音巨量引擎成人教育行业生态大会”,探讨分享优质内容传播,服务万千学员。 ...
摩托罗拉Razr 2026(R... IT之家 4 月 22 日消息,摩托罗拉宣布新一代 Razr 折叠手机将于 4 月 29 日在美国发...
库克卸任,特纳斯领航:苹果新纪... 苹果首席执行官蒂姆·库克将卸任,硬件工程主管约翰·特纳斯将接任,苹果公司今天宣布此事。 库克将在夏季...