我对 int (*p[2])[3] 的理解,不知对不对,请大家指正

sqlnew 2013-08-29 04:02:00
int (*p[2])[3]
p是一个数组,数组的元素有2个,数组里面的元素是指针,
这2个指针中每个指针指向的是有3个int类型元素的数组。

不知道我以上的理解对不对,请大家指正!
谢谢。
...全文
346 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
BT_Dana 2013-08-30
  • 打赏
  • 举报
回复
引用 楼主 sqlnew 的回复:
int (*p[2])[3] p是一个数组,数组的元素有2个,数组里面的元素是指针, 这2个指针中每个指针指向的是有3个int类型元素的数组。 不知道我以上的理解对不对,请大家指正! 谢谢。
对的, c语言声明可以很复杂, 但是有规律可循的: 就是→ ← → ← → ... 这样的顺序 所以int (*p[2])[3]解析起来就是这样的: 先找出变量名p, 然后 先看右边的[2]: 则p是有2个元素的数组 再看左边的*: 则数组里存的是指针 再看右边的): 遇到括号返回 再看左边的(: 遇到括号返回 再看右边的[3]: 则指针指向的是有3个元素的数组 再看左边的int: 表示这含有3个元素的数组, 里面存的是int 综合起来就是你说的了, p是个数组(有2元素), 数组里存的是指针, 指针指向的是数组(有3元素). 所以c有很多看似非常麻烦的声明, 但是都能第一眼看出来声明的本质, 声明的这个变量到底是个数组, 还是指针, 还是??? 只需向→看一眼就可以了
艾薇儿More 2013-08-30
  • 打赏
  • 举报
回复
引用 5 楼 AnYidan 的回复:
c 的声明是容易使人迷糊之处,如何使用就如何声明,c 专家编程 有仔细讲解
+10000
AnYidan 2013-08-29
  • 打赏
  • 举报
回复
c 的声明是容易使人迷糊之处,如何使用就如何声明,c 专家编程 有仔细讲解
碼上道 2013-08-29
  • 打赏
  • 举报
回复
引用 楼主 sqlnew 的回复:
int (*p[2])[3] p是一个数组,数组的元素有2个,数组里面的元素是指针, 这2个指针中每个指针指向的是有3个int类型元素的数组。 不知道我以上的理解对不对,请大家指正! 谢谢。
理解正确。使用typeid(p).name()获取的字符串是A2_PA3_i
max_min_ 2013-08-29
  • 打赏
  • 举报
回复
是定义一个类型为int(*)[3]的数组p
lin5161678 2013-08-29
  • 打赏
  • 举报
回复
对 字数补丁
赵4老师 2013-08-29
  • 打赏
  • 举报
回复
//char (*(*x[3])())[5];//x是什么类型的变量?
//
//分析C语言声明,关键是搞清楚这个变量是个什么东西(函数、指针、数组),
//是函数那么剩下的就是他的参数和返回值,
//是指针那剩下部分是说明他指向什么,
//是数组剩下的部分就是说明数组的成员是什么类型。
//解析C语言声明规则:
//从左侧第一个标识符开始,按照优先级进行结合。*表示是..的指针,const表示只读的,volatile表示可变的,[]表示是数组,()表示是函数。
//
//x和[3]结合说明是一个大小为3的数组,该数组指向了一个指针,该指针指向一个函数,该函数的无参数,返回一个指针,该指针指向一个大小为5的char型数组
#include <stdio.h>
#include <typeinfo.h>
char num[5];
char (*x00())[5] {
    return #
}
int main() {
    char (*x000)[5];//返回值
    char (*(x00)())[5];//函数原型,参数为空,返回值为指针
    char (*(*x0)())[5];//数组的元素,是个函数指针
    char (*(*x[3])())[5];//是个数组,大小为3

    x0 = x00;
    x[0] = x0;
    x[1] = x0;
    x[2] = x0;
    printf("typeid(x).name() is %s\n",typeid(x).name());
    return 0;
}
//typeid(x).name() is char (* (__cdecl**)(void))[5]
本课程以2021年度大数据技术学习为背景,重点围绕Spark 3.0框架展开系统讲解。课程内容基于2020年9月官方正式发布的稳定版本Spark 3.0.1进行设计,确保所学技术紧跟行业前沿。整个教学体系划分为九个核心模块,涵盖从基础到高级的完整知识路径。 首先从Spark集群环境部署与配置入手,奠定实际操作基础。随后深入剖析Spark Core核心原理与编程模型,掌握分布式计算基础。课程进一步延伸至实时数据处理领域,系统讲解Spark Streaming流式计算框架及其应用场景。 在数据查询与分析部分,重点介绍Spark SQL模块,学习结构化数据处理方法。同时结合Structured Streaming技术,探讨现代流批一体架构的实现方式。通过综合实战案例,演示如何将各模块知识融会贯通,解决复杂业务场景中的数据处理问题。 为适应多样化开发需求,课程专门设置多语言编程章节,展示Scala、Python、Java等不同语言在Spark生态中的开发模式。针对Spark 3.0版本革新,详细解读其在性能优化、API改进及功能增强方面的最新特性。最后部分聚焦系统性能调优方法论,包括资源配置、执行计划优化等进阶内容,全面提升分布式系统运维能力。 资源来源于网络分享,仅用于学习交流使用,勿用于商业,如有侵权联系我删除!

70,037

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧