cpp c++summary笔记 复杂类型 “right-left” rule

文章详细解释了如何使用右左规则来解析复杂的C/C++类型声明,包括指针、数组和函数指针的组合。通过示例,如`int*(*(*fp1)(int))[10]`,阐述了如何确定类型的左右关系,帮助读者理解这类声明的含义,例如fp1是一个指向返回指针的函数,该指针指向一个包含10个int指针的数组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

复杂类型 “right-left” rule

       先向右走在向左走,循环往复,右侧的终止为看到右括号,右中括号,左侧为左括号,指针(或其他int等)。

符号读作
*指向AA的指针(总在左侧)
[]容纳AA的数组(总在左侧)
()返回AA的函数(总在右侧)
int * (* (*fp1) (int) ) [10];
开始fp1主体
右括号终止
i n t ∗ ( ∗ ( ∗ f p 1 ) ( i n t ) ) [ 10 ] ; int ^* (^* (^ {\color{red}*}fp1) (int) ) [10]; int((fp1)(int))[10];fp1是个指向AA的指针
i n t ∗ ( ∗ ( ∗ f p 1 ) ( i n t ) ) [ 10 ] ; int ^* (^* (^*fp1) {\color{red} (int) }) [10]; int((fp1)(int))[10];指针fp1指向返回BB的函数
i n t ∗ ( ∗ ( ∗ f p 1 ) ( i n t ) ) [ 10 ] ; int ^* (^ {\color{red}*} (^ * fp1) (int) ) [10]; int((fp1)(int))[10];指针fp1指向返回指针的函数
i n t ∗ ( ∗ ( ∗ f p 1 ) ( i n t ) ) [ 10 ] ; int ^* (^* (^ * fp1) (int) ) {\color{red}[10]}; int((fp1)(int))[10];指针fp1指向返回指针的函数,指针指向一个数组
i n t ∗ ( ∗ ( ∗ f p 1 ) ( i n t ) ) [ 10 ] ; int ^{\color{red}*} (^* (^ * fp1) (int) ) [10]; int((fp1)(int))[10];指针fp1指向返回指针的函数,指针指向一个数组,数组中的元素是指针
i n t ∗ ( ∗ ( ∗ f p 1 ) ( i n t ) ) [ 10 ] ; {\color{red}int} ^* (^* (^ * fp1) (int) ) [10]; int((fp1)(int))[10];指针fp1指向返回指针的函数,指针指向一个数组,数组中的元素是指针,指针指向int类型
int* p,q;p一个指针,q是一个简单的int
float ( * ( *b()) [] )();b是一个返回指向数组的指针的函数,数组中盛放的元素是指向返回float的函数指针

函数指针

int f(int x) {printf(x);}//函数f就是一个指针(类似数组的名称)
int (*p)(int) = f;//定义函数指针p,用f初始化,调用时 p()

参考与更多

  • https://www.codeproject.com/Articles/7042/How-to-interpret-complex-C-C-declarations
  • const* p const char *p; //和char const *p 数据为常量 https://www.nowcoder.com/questionTerminal/3f10681845d049089f0853114dc19481?toCommentId=55172

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值