理解函数声明

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章 语法“陷阱”

posted @ 2017-04-27 16:09  wojiaowoen  阅读(152)  评论(0编辑  收藏  举报