我在其中一个旧文件中看到了一段代码。
void (*const m_exec[N_EXECS])(void) =
{
#define PROCESS_DEF_TIMED(name) name, // defines macro for use in proclist.h
#define PROCESS_TIMED // define switch for section in proclist.h
#include "proclist.h"
#undef PROCESS_TIMED // undefine switch
#undef PROCESS_DEF_TIMED // undefines macro
};
我无法理解此代码的含义。这是一个带声明和函数定义的函数指针吗?但是如果我尝试像下面那样声明类似的函数指针,我会得到编译错误
void (*voidFptr)(void) =
{
printf("Hello\n");
}
这里的#define是什么?为什么这是我不确定的功能。
答案 0 :(得分:7)
此:
void (*const m_exec[N_EXECS])(void)
是你在C中声明一个函数指针数组的方式。你并不是唯一一个发现这个难以阅读的人。它声明了一个长度为N_EXECS
的数组,其中数组中的每个元素都是一个不带参数的函数,并返回一个指向const-void的指针。
它后面的括号内的块是数组初始化器;可能proclist.h
中有一个完整的函数指针声明列表,这基本上是将它们粘贴到这个数组中。如果您想查看#include
之后实际发生的情况,可以使用编译器的-E
标志。因此,如果这是main.c
,您将运行:
gcc -E -Ipath/to/headers -Iother/path/to/headers main.c
它会给你一个(可能是巨大的)源代码转储,这是通过预处理器推送该文件并评估所有#include
语句的结果。
编辑:错过了你的上一个问题。
可能(这是猜测而没有看到proclist.h
),其定义的内容会改变proclist.h
的内容。例如,如果它包含:
#ifdef PROCESS_TIMED
&function1_timed,
&function2_timed
#else
&function1,
&function2
#endif
然后#define PROCESS_TIMED
会更改m_exec
数组中的内容。