news 2026/5/1 8:45:32

二维数组指针操作

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
二维数组指针操作

以下是 C++ 中对二维数组指针操作的演示,主要展示了如何通过指针访问二维数组中的元素。我们来逐行讲解其含义和作用。


🧩 假设前提

在看这段代码之前,我们需要知道一些上下文(虽然图中未显示):

通常这种代码出现在如下场景中:

intarr[2][4]={{1,2,3,4},{5,6,7,8}};int(*p2)[4]=arr;// p2 是指向含有 4 个 int 的数组的指针

即:p2是一个指向int[4]类型的指针,也就是指向二维数组的一行。


🔍 逐行解析代码

cout<<"**************"<<endl;

输出一行星号作为分隔符,便于调试输出查看。

cout<<p2<<endl;

打印p2指针本身的值,即第一行数组的首地址(例如:0x7ffeeb3f2a40)。

//取出数组地址cout<<*p2<<endl;

*p2表示解引用p2,得到它所指向的第一个一维数组(即arr[0])的首地址。

注意:此时*p2实际上就是arr[0]的地址,也等于&arr[0][0],所以这个输出和上面的p2可能相同(因为p2*p2在地址上可能一致,但类型不同)。

重点理解:

  • p2int(*)[4]类型 → 指向整个行
  • *p2int[4]类型 → 解引用后是一个数组,但编译器会将其退化为int*(指向第一个元素)
  • 所以*p2等价于&arr[0][0],即arr[0]的首地址
//第二行数组首地址cout<<p2+1<<endl;//偏移元素*容量 16个字节

p2 + 1表示将指针p2向后移动一个int[4]的大小。

因为每个int[4]4 * sizeof(int)= 16 字节(假设int是 4 字节),所以这一步跳过了第一行,指向了第二行的首地址(即arr[1]的地址)。

//取出数组地址//int*cout<<*(p2+1)<<endl;

*(p2 + 1)就是解引用第二行的地址,结果是arr[1]的首地址(即&arr[1][0]),也就是arr[1]数组本身。

cout<<**(p2+1)<<endl;

**(p2 + 1)

  • (p2 + 1)得到第二行的地址
  • *(p2 + 1)得到第二行的首地址(&arr[1][0]
  • 最后再*(*(p2 + 1))就是取该地址的内容 →arr[1][0]的值

所以这里输出的是5(如果数组初始化为{1,2,3,4}, {5,6,7,8}

//先偏移行地址,再在这一行中偏移元素地址cout<<*(*(p2+1)+1)<<endl;cout<<*(*(p2+1)+2)<<endl;cout<<*(*(p2+1)+3)<<endl;

这些语句是在第二行中访问后续元素:

  • *(p2 + 1)→ 第二行首地址(&arr[1][0]
  • *(p2 + 1) + 1→ 指向arr[1][1]的地址
  • *(*(p2 + 1) + 1)→ 获取arr[1][1]的值 →6

同理:

  • *(*(p2 + 1) + 2)arr[1][2]7
  • *(*(p2 + 1) + 3)arr[1][3]8

✅ 总结:关键点

表达式含义示例值(基于arr[2][4] = {{1,2,3,4},{5,6,7,8}}
p2第一行的地址&arr[0]
*p2第一行的首元素地址&arr[0][0]
p2 + 1第二行的地址&arr[1]
*(p2 + 1)第二行的首元素地址&arr[1][0]
**(p2 + 1)第二行第一个元素值5
*(*(p2 + 1) + 1)arr[1][1]6
*(*(p2 + 1) + 2)arr[1][2]7
*(*(p2 + 1) + 3)arr[1][3]8

🎯 核心思想

  • 二维数组本质是一维连续内存的逻辑划分。
  • 使用指针int (*)[n]可以安全地遍历每一行。
  • 多层解引用可以实现类似arr[i][j]的效果。
  • 指针算术中,p2 + 1跳过整行(不是单个元素),这是“数组指针”与“普通指针”的区别。

💡 小技巧:等价写法

你可以把*(*(p2 + 1) + j)写成更简洁的形式:

(*p2)[j]// 第一行第 j 列(*(p2+1))[j]// 第二行第 j 列

或者直接用下标:

arr[1][j]

🧪 示例完整程序(供测试)

#include<iostream>usingnamespacestd;intmain(){intarr[2][4]={{1,2,3,4},{5,6,7,8}};int(*p2)[4]=arr;cout<<"**************"<<endl;cout<<"p2: "<<p2<<endl;cout<<"*p2: "<<*p2<<endl;cout<<"p2+1: "<<p2+1<<endl;cout<<"*(p2+1): "<<*(p2+1)<<endl;cout<<"**(p2+1): "<<**(p2+1)<<endl;cout<<"*(*(p2+1)+1): "<<*(*(p2+1)+1)<<endl;cout<<"*(*(p2+1)+2): "<<*(*(p2+1)+2)<<endl;cout<<"*(*(p2+1)+3): "<<*(*(p2+1)+3)<<endl;return0;}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 4:46:35

程序员必看!企业级私有化部署开源大模型选型与实战指南(建议收藏)

文章介绍了支持私有化部署的开源大模型选型与部署指南&#xff0c;包括国际主流和中文优秀模型。详细分析了个人开发、中小企业和大规模生产三种场景下的硬件配置、软件框架和性价比方案&#xff0c;帮助企业和开发者根据需求选择合适的模型和部署架构&#xff0c;实现数据安全…

作者头像 李华
网站建设 2026/5/1 7:36:43

从零开始:Gitee 仓库创建与本地项目纳管全流程详解

目录 一、Gitee 仓库创建:打好代码托管的基础 1.1 准备工作 1.2 仓库创建步骤 二、本地生成 SSH 公钥:实现免密提交代码 2.1 SSH 公钥的作用原理 2.2 本地生成 SSH 公钥的步骤 步骤 1:检查 Git 环境 步骤 2:打开命令行工具 步骤 3:执行生成公钥的命令 2.3 将公钥…

作者头像 李华
网站建设 2026/5/1 6:17:31

走向全栈:前后端状态认知差异与设计边界的深度探讨

文章目录 引言&#xff1a;为何关注前后端状态认知差异全栈开发的兴起与前后端分离的现状状态管理在现代应用中的重要性前后端协作中的常见误解 登录态的归属&#xff1a;前端状态还是后端状态&#xff1f;登录态的定义与实现方式前端如何管理登录态后端对登录态的支持与要求案…

作者头像 李华
网站建设 2026/4/4 3:56:45

Java毕设选题推荐:基于Java的小说三体科幻社区管理系统的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/1 5:06:49

AI版“马后炮”?大模型的「因果注意力」到底是啥?

AI版“马后炮”?大模型的「因果注意力」到底是啥? 目录 AI版“马后炮”?大模型的「因果注意力」到底是啥? 这一切的根源,都指向大模型天生自带的**「因果注意力」机制**。 🔍 什么是「因果注意力」?用“写日记”打比方 📝 生活化举例 🧠 底层原理:Transformer里的…

作者头像 李华
网站建设 2026/4/25 8:17:39

越疆科技转化应用调研考察解读-万祥军| 国研智库·中国国政研究

越疆科技转化应用调研考察解读-万祥军| 国研智库中国国政研究“近年来&#xff0c;随着全球新一轮科技革命和产业变革深入发展&#xff0c;机器人技术作为智能制造的核心装备&#xff0c;正加速向各行业渗透融合。”调研考察中国际科学院组织代表兼国际科学院委员会执委万祥军解…

作者头像 李华