当前位置: 首页 > news >正文

二维数组指针操作

以下是 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;}

http://www.jsqmd.com/news/299469/

相关文章:

  • Python函数
  • Spring事务的传播机制
  • 【柔性作业车间调度FJSP】基于蛇鹫优化算法(SBOA)求解柔性作业车间调度问题(FJSP)研究附Matlab代码
  • 【柔性作业车间调度问题】基于四种多目标优化算法(NSPSO、NSOOA、NSDBO、NSCOA)求解柔性作业车间调度问题(FJSP)对比研究附Matlab代码
  • 【柔性作业车间调度问题FJSP】基于部落竞争与成员合作算法CTCM求解柔性作业车间调度问题(FJSP)研究附Matlab代码
  • ppo导航依赖第一步,那是rnn好还是transformer
  • 【柔性作业车间调度FJSP】基于河马优化算法HO求解柔性作业车间调度问题(FJSP)研究附Matlab代码
  • Java毕设项目:基于springboot的生日商城的设计与实现(源码+文档,讲解、调试运行,定制等)
  • SpringBoot 2.0 + Nacos + Sentinel 流控规则集中存储至nacos完整配置步骤
  • Java计算机毕设之基于springboot的社区志愿者服务系统SpringBoot驱动的居民志愿服务智慧系统(完整前后端代码+说明文档+LW,调试定制等)
  • 大模型开发面试全攻略:从基础到进阶的通关秘籍_AI大模型面试指南(含答案)!
  • 本地运行!开源AI音乐生成器HeartMuLa完整安装与使用指南
  • 大模型学习不迷茫!6大模块助你快速入门,实现职业跃迁!学习大模型的顺序,千万别弄反了
  • 程序员必看!企业级私有化部署开源大模型选型与实战指南(建议收藏)
  • 【保姆级教程】从0到1掌握大模型(LLM)学习路线图,建议收藏!_我愿称之为26年最详细的大模型学习路线!
  • AI Agent完全指南:从零开始掌握大模型新方向
  • 基于Spring AI的电商客服RAG系统实战教程,小白也能轻松上手
  • 2025.12.14日周报——文献阅读
  • 百炼-工作流-sb
  • 深入解析:Categraf | 国产化采集器实现:SQL Server 数据库指标采集、可视化、异常告警全流程
  • 1.25假期记录
  • 全网最全MBA必看TOP9 AI论文工具测评
  • 基于51单片机超声波智能垃圾桶控制系统红外感应舵机控制 DIY
  • 结构体struct类型定义的意义和一个vscode实用插件
  • 基于51单片机超声波智能垃圾桶控制系统
  • SpringBoot - yml配置文件
  • 【毕业设计】基于springboot的社会养老平台的设计与实现(源码+文档+远程调试,全bao定制等)
  • Hadoop数据过滤:高效查询的预处理
  • 【毕业设计】基于springboot的社区志愿者服务系统(源码+文档+远程调试,全bao定制等)
  • 【课程设计/毕业设计】 基于Spring Boot的智能养老服务平台基于springboot的社会养老平台的设计与实现【附源码、数据库、万字文档】