求解一个函数指针的问题

小熊之怒 2018-06-02 05:13:26
在c陷阱与缺陷中看到一个例子,很有意思,但是不明白,求解。
原函数: (*(void(*)())0)(); 作者使用 typedef 重写之后如下:

typedef  void (*funcptr)();
(*(funcptr)0)();

个人认为作者用typedef 写的不对,
我的想法:

typedef void(*)() funcptr
((*funcptr)0)();

对于typedef理解的不是很清楚,所以有点懵,求大神给指导,本来想通过打印地址的方法来分析下,可是ubantu编译都有问题。
只能来求助大佬们了。求解
...全文
1147 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2018-06-06
  • 打赏
  • 举报
回复
不要迷信书、考题、老师、回帖; 要迷信CPU、编译器、调试器、运行结果。 并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。 任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
//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 (*(*x[3])())[5];//是个数组,大小为3
    char (*(*x0  )())[5];//数组的元素,是个函数指针
    char (*( x00 )())[5];//函数原型,参数为空,返回值为指针
    char (*  x000   )[5];//返回值

    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]
wxf54318 2018-06-06
  • 打赏
  • 举报
回复
(funcptr)0这是将0强制转换为函数指针类型,0是一个地址,也就是说一个函数存在首地址为0的一段区域内 funcptr是二级指针,你*funcptr不就是二级指针了吗,有什么意义啊
小熊之怒 2018-06-04
  • 打赏
  • 举报
回复
引用 1 楼 qq_36751214 的回复:
typedef void(*)() funcptr ;这么写意思是对的,不过 typedef void(funcptr*)() ;是标准写法,另外函数名即是地址。
对typedef不是很熟悉,我再研究下。看看typedef的用法
小熊之怒 2018-06-04
  • 打赏
  • 举报
回复
引用 5 楼 paschen 的回复:
从理解上确实第二种更好理解,但标准要求的是第一种形式
我再研究下
自信男孩 2018-06-04
  • 打赏
  • 举报
回复
注意typedef 和#define还是有区别的。建议对比一下这两种写法和意义的不同。
AlbertS 2018-06-04
  • 打赏
  • 举报
回复
typedef void(funcptr*)() 这么写是对的,其中funcptr就是函数指针的类型
paschen 2018-06-02
  • 打赏
  • 举报
回复
从理解上确实第二种更好理解,但标准要求的是第一种形式
zhouqunhai 2018-06-02
  • 打赏
  • 举报
回复
楼上是正解。
真相重于对错 2018-06-02
  • 打赏
  • 举报
回复
如果不用typedef 大概应该这样写
void(*funcptr)();
void test() {
	printf("ok");
};

int main()
{
	funcptr = test;
	funcptr();
    return 0;
}
真相重于对错 2018-06-02
  • 打赏
  • 举报
回复
typedef void(*)() funcptr 这个写法不对,试一下就知道了
宁南学者 2018-06-02
  • 打赏
  • 举报
回复
typedef void(*)() funcptr ;这么写意思是对的,不过 typedef void(funcptr*)() ;是标准写法,另外函数名即是地址。

69,373

社区成员

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

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