0

0

C++多维数组如何内存布局 行优先与列优先存储分析

P粉602998670

P粉602998670

发布时间:2025-07-01 10:23:01

|

545人浏览过

|

来源于php中文网

原创

c++中多维数组的内存布局是按行优先(row-major order)方式存储的。具体表现为最右边的下标变化最快,最左边的变化最慢,例如二维数组int arr3在内存中的排列顺序是按行连续存储的:arr0, arr0, arr0, arr0, arr1, arr1, arr1, arr1, arr2, arr2, arr2, arr2;这种行优先方式与列优先(column-major order)相对,后者被fortran、matlab等语言采用;为了高效访问多维数组,应遵循内存布局规则,在c++中最内层循环应控制最右边的下标(即“列”),以避免跨行频繁跳转访问,从而提高缓存命中率并提升性能;例如对于int arr100,推荐先遍历行再遍历列的方式操作元素;多维数组本质上是“数组的数组”,因此在传参时必须指定除第一维外的所有维度大小,以便编译器计算偏移地址;对于二维数组t arrm,访问arri的内存地址计算公式为base_address + (i n + j) sizeof(t),而三维数组t arrl[n]则为base_address + (k m n + i n + j) sizeof(t)。

C++多维数组如何内存布局 行优先与列优先存储分析

C++中多维数组的内存布局是按照行优先(Row-major Order)方式进行存储的。也就是说,最右边的下标变化最快,最左边的变化最慢。理解这一点对优化访问顺序、提高缓存命中率非常重要。

C++多维数组如何内存布局 行优先与列优先存储分析

什么是行优先(Row-major Order)

在C++中,当你声明一个二维数组,比如:

C++多维数组如何内存布局 行优先与列优先存储分析
int arr[3][4];

它在内存中的排列顺序是这样的:

立即学习C++免费学习笔记(深入)”;

arr[0][0], arr[0][1], arr[0][2], arr[0][3],
arr[1][0], arr[1][1], arr[1][2], arr[1][3],
arr[2][0], arr[2][1], arr[2][2], arr[2][3]

可以看到,数组是按“行”连续存储的,每行内部是连续的,而每一列之间可能并不连续(除非访问的是同一行内的元素)。这种布局方式就是典型的行优先

C++多维数组如何内存布局 行优先与列优先存储分析

行优先 vs 列优先(Column-major Order)

  • 行优先(Row-major):C/C++、Python(NumPy默认)、C# 等语言采用。
  • 列优先(Column-major):Fortran、MATLAB、R 等语言使用这种方式。

举个例子,考虑一个2x2矩阵:

[ a b ]
[ c d ]
  • 行优先存储顺序为:a, b, c, d
  • 列优先存储顺序为:a, c, b, d

如果你是从其他语言转过来的,在处理数组遍历时就容易踩坑。例如在MATLAB里先遍历列效率高,而在C++里就应该优先遍历行。


如何高效访问多维数组

为了充分利用CPU缓存,访问顺序应尽量符合内存布局。也就是说,在C++中应该:

  • 最内层循环控制最右边的下标(即“列”)
  • 避免跨行频繁跳转访问

举个例子,对于 int arr[100][100];,推荐的访问方式是:

for (int i = 0; i < 100; ++i) {
    for (int j = 0; j < 100; ++j) {
        // 操作 arr[i][j]
    }
}

而不是:

科大讯飞-AI虚拟主播
科大讯飞-AI虚拟主播

科大讯飞推出的移动互联网智能交互平台,为开发者免费提供:涵盖语音能力增强型SDK,一站式人机智能语音交互解决方案,专业全面的移动应用分析;

下载
for (int j = 0; j < 100; ++j) {
    for (int i = 0; i < 100; ++i) {
        // 操作 arr[i][j] ← 不推荐!跳跃式访问
    }
}

后者会导致频繁的缓存不命中,影响性能,尤其是在大数组时更明显。


多维数组的本质是“数组的数组”

在C++中,多维数组本质上是一个“数组的数组”。例如:

int arr[3][4];

可以看作是有一个长度为3的一维数组,每个元素又是一个长度为4的整型数组。

因此:

  • arr[i] 是一个类型为 int[4] 的数组
  • arr[i][j] 才是实际的 int 类型值

这也解释了为什么多维数组在传参时需要指定除第一维外的所有维度大小,例如:

void func(int arr[][4]) { ... } // 必须指定列数

因为编译器要根据列数来计算偏移地址。


内存偏移计算公式

对于一个二维数组 T arr[M][N],访问 arr[i][j] 的内存地址可以通过如下方式计算:

base_address + (i * N + j) * sizeof(T)

如果是三维数组 T arr[L][M][N],则地址为:

base_address + (k * M * N + i * N + j) * sizeof(T)

理解这个公式有助于手动实现动态多维数组或进行底层操作。


基本上就这些。虽然看起来不复杂,但在性能敏感的场景下,访问顺序和内存布局的影响不容忽视。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
fprintf在matlab中的用法
fprintf在matlab中的用法

fprintf是MATLAB中用于格式化输出的函数。fprintf的基本语法为“fprintf(fileID, format, A)”,其中,fileID是一个标识符,用于指定要写入的文件,如果要将数据写入到命令窗口中,则可以使用1作为fileID的值,format是一个字符串,用于指定输出的格式,A是要输出的数据。

485

2023.09.28

数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

707

2023.10.12

Matlab中length函数的用法
Matlab中length函数的用法

在Matlab中,length函数用于返回向量、数组或字符串中的元素个数。想了解更多length函数的相关内容,可以阅读本专题下面的文章。

313

2023.11.22

Matlab中axis函数用法
Matlab中axis函数用法

在Matlab中,axis函数用于控制坐标轴的范围和比例。想了解更多axis函数的相关内容,可以阅读本专题下面的文章。

773

2023.11.23

subplot在matlab中的用法
subplot在matlab中的用法

subplot在matlab中用于在同一个图窗中创建多个子图。通过指定子图的行数、列数和当前绘图位置,可以在每个子图中绘制不同的图形。想了解更多subplot在matlab中的用法,可以访问下面的文章。

142

2023.11.27

scilab和matlab的区别
scilab和matlab的区别

scilab和matlab的区别:1、注释符号;2、预设变量的表示;3、操作符的用法;4、矩阵的定义与调用;5、程序的编辑与执行;6、数据类型;7、函数库;8、图形界面;9、社区支持与生态系统;10、跨平台兼容性;11、价格。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.12.11

Matlab如何四舍五入
Matlab如何四舍五入

Matlab可以通过round函数和格式化输出函数来对数值来进行四舍五入操作。更多关于Matlab相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

397

2023.12.12

Matlab中axis函数用法介绍
Matlab中axis函数用法介绍

在Matlab中,axis函数用于设置当前坐标轴的范围和刻度。想了解更多axis函数的相关内容,可以阅读本专题下面的文章。

163

2023.12.13

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.3万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号