C 函数指针声明和函数定义一起

C 函数指针声明和函数定义一起,c,mingw,codeblocks,C,Mingw,Codeblocks,我在一个旧文件中看到了一些代码 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

我在一个旧文件中看到了一些代码

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");
}
还有,这里定义了什么?我不确定这是函数内部的原因。

这是:

void (*const m_exec[N_EXECS])(void)
是用C语言声明函数指针数组的方式。您并不是唯一一个发现这一点的人。它声明了一个长度为
N_EXECS
的数组,其中数组中的每个元素都是一个不带参数的函数,并返回指向常量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
数组中的结果。

它将从
“proclist.h”
中包含的列表填充函数指针数组。通过预处理器运行该文件并查看预处理的输出。是否查看了头文件?也许你也注意到原文的语法与你的不同。在程序代码中,每一个字符都很重要,甚至在注释和字符串中也是如此。我们是否可以声明一个函数指针并一起定义函数,比如'void(*voidFptr)(void)={printf(“Hello\n”);}通过定义一个函数,实质上就是“声明一个函数指针”;如果有
void voidf(void){printf(“Hello\n”);}
,则
voidf
voidf
是等效的有效函数指针。