OpenCV: Mat存储方式全解析-单通道、多通道内存布局详解

在使用 OpenCV 的过程中,我们经常会接触 cv::Mat 这种图像矩阵类型。理解 Mat 在内存中的布局非常重要,尤其是做指针访问、性能优化、SIMD(如 AVX/NEON)加速时。本文将详细介绍:

  • Mat 的存储方式

  • 单通道 vs 多通道的内存布局

  • 如何用指针访问某个像素

  • 判断 Mat 是否连续

  • 实战图示与代码

1️⃣ Mat 的存储特性

cv::Mat 是一个行优先(Row-major)、通常连续(Continuous)的多维数组,数据区存储像素值。

  • 行优先:按行存储,每一行像素紧挨着。

  • 通道连续:多通道像素的各通道值依次存储。

  • 可能有行间对齐填充 :当 Mat 是 ROI(子图)或手动创建带 padding 的图像时,行与行之间可能有"间隙",此时 Mat::isContinuous() 会返回 false

2️⃣ 单通道示例(CV_8UC1)

假设一张 3×3 的灰度图:

在内存中是这样的:

cpp 复制代码
data →
[10][20][30][40][50][60][70][80][90]

每个像素占用 1 字节,行优先顺序排列。

3️⃣ 多通道示例(CV_8UC3)

假设一张 2×3 的彩色图像,每个像素是 (B,G,R)

内存布局:

cpp 复制代码
Row 0: [10][20][30][40][50][60][70][80][90]
Row 1: [11][21][31][41][51][61][71][81][91]

注意:

  • 并不是"打包成一个 24 位整数",而是 3 个独立的字节 挨着存储。

  • 每像素大小 = elemSize() = 3 字节。

4️⃣ 像素索引 → 内存地址

要访问 (row, col) 的像素,可以用

cpp 复制代码
cv::Mat img = cv::imread("test.png"); // 假设是 CV_8UC3
int row = 1, col = 2;

// 定位到(row,col)的像素指针
uchar* pixelPtr = img.data + row * img.step + col * img.elemSize();

uchar B = pixelPtr[0];
uchar G = pixelPtr[1];
uchar R = pixelPtr[2];
  • img.data:首地址

  • img.step:每行占用字节数

  • img.elemSize():每个像素占用字节数(多通道时>1)

5️⃣ 判断 Mat 是否连续

有些操作(如 memcpy、手动指针循环)需要连续内存

cpp 复制代码
if (img.isContinuous()) {
    // 数据连续,可以直接用指针一次性遍历所有像素
} else {
    // 数据不连续,需要按行处理
}

6️⃣ 图示

下面是 2×3,CV_8UC3 的直观示意图:

cpp 复制代码
内存布局 (2x3, CV_8UC3):
data →
┌───────────── Row 0 ─────────────┐┌───────────── Row 1 ─────────────┐
[10][20][30][40][50][60][70][80][90][11][21][31][41][51][61][71][81][91]
└─────────────  9 * 1 byte ───────┘└─────────────  9 * 1 byte ───────┘

7️⃣ 小结

  • cv::Mat 默认是行优先、连续存储。

  • 多通道像素值按通道顺序紧挨着。

  • 使用 data + row*step + col*elemSize() 快速定位像素。

  • isContinuous() 判断是否可以一次性处理所有数据。

相关推荐
aihuangwu12 分钟前
如何把豆包的回答导出
人工智能·ai·deepseek·ds随心转
好奇龙猫14 分钟前
【人工智能学习-AI入试相关题目练习-第十六次】
人工智能·学习
bing.shao18 分钟前
Golang 开发者视角:解读《“人工智能 + 制造” 专项行动》的技术落地机遇
人工智能·golang·制造
LOnghas121118 分钟前
玉米目标检测实战:基于YOLO13-C3k2-RFAConv的优化方案_1
人工智能·目标检测·计算机视觉
量子-Alex28 分钟前
【大模型课程笔记】斯坦福大学CS336 课程环境配置与讲座生成完整指南
人工智能·笔记
冬奇Lab32 分钟前
一天一个开源项目(第9篇):NexaSDK - 跨平台设备端 AI 运行时,让前沿模型在本地运行
人工智能·开源
量子-Alex43 分钟前
【大模型技术报告】Qwen2-VL大模型训练过程理解
人工智能
java1234_小锋1 小时前
【AI大模型舆情分析】微博舆情分析可视化系统(pytorch2+基于BERT大模型训练微调+flask+pandas+echarts) 实战(上)
人工智能·flask·大模型·bert
新缸中之脑1 小时前
Imagerouter.io: 免费图像生成API
人工智能
MM_MS1 小时前
Halcon图像点运算、获取直方图、直方图均衡化
图像处理·人工智能·算法·目标检测·计算机视觉·c#·视觉检测