1 (*(void (*)())0) ();
构造的规则:按照使用的方式来声明,
任何C变量的声明都有两部分组成:类型以及一组类似表达式的声明符。声明符从表面看与表达式有些类似,对它求值应该返回一个声明中给定类型的结果。
下面将对上面的函数声明进行解释:
1 float (*h)();//h表示一个指向返回类型是浮点型的函数的指针。
1 (float (*)())//表示一个“指向返回值为浮点类型的函数的指针”的类型转换符。
(void (*) ()) 0:表示对0进行类型转换,转换为一个返回类型为void的函数指针;再进行函数调用。
上面的声明与下面的声明等价:
1 typedef void (*funcptr)(); 2 (*(funcptr)0)();
另一种:
1 void (*signal(something))(int);
something代表了signal函数的参数类型。
对上面函数声明的理解如下:传递适当的参数以调用signal函数,对signal函数返回值(为函数指针类型)解除引用(也就是进行取址操作),然后传递一个整形参数解除引用后所得函数,最后返回值为void类型。
*signal(something)函数返回一个返回值为void,参数为int类型的函数指针。
signal函数的参数(something)有两个:一个整型的信息编号,以及一个指向用户定义的信号处理函数的指针。
综上所述:
1 void (*signal(int, void (*)(int)))(int);
同样,使用typedef可以简化上面的函数声明:
1 typedef void (*HANDLER)(int); 2 HANDLER signal(int, HANDLER);
参考书籍:《C陷阱与缺陷》第2章 语法“陷阱”