2

我正在尝试初始化一个结构数组。该结构包含一个函数指针作为其数据成员之一。但是我的编译器给了我一个错误,抱怨初始化器元素不是常量。如何使用声明的函数指针初始化数组?

typedef void (*write_func_ptr_t)( void**, size_t*, char*, const size_t);
typedef bool (*read_func_ptr_t)( char*, const void*, const size_t);

write_func_ptr_t generate_basic_msg_ptr;
read_func_ptr_t handle_basic_msg_ptr;
write_func_ptr_t generate_reg_msg_ptr;
read_func_ptr_t handle_reg_msg_ptr;

struct supported_msg_info
{
    const char* const type;
    const write_func_ptr_t write_func;
    const read_func_ptr_t read_func;
};

static struct supported_msg_info SUPP_MESSAGES[] = {
    { "basic", generate_basic_msg_ptr, handle_basic_msg_ptr },
    { "registration", generate_reg_msg_ptr, handle_reg_msg_ptr }
};
4

2 回答 2

2

您可以这样做,添加函数声明并使它们与函数指针类型匹配,如下所示

void generate_basic_msg_ptr(void **, size_t *, char *, const size_t);
bool handle_basic_msg_ptr(char *, const void *, const size_t);
void generate_reg_msg_ptr(void **, size_t *, char *, const size_t);
bool handle_reg_msg_ptr(char *, const void *, const size_t);

但是根据你的评论

函数的定义将在运行时使用 dlsym – agranum 59 秒前从共享库中拉入

你真正需要的是这个

struct supported_msg_info
{
    const char *const type;
    /* remove the const qualifier */
    write_func_ptr_t write_func;
    read_func_ptr_t read_func;
};

static struct supported_msg_info SUPP_MESSAGES[] = {
    {"basic", NULL, NULL},
    {"registration", NULL, NULL}
};

然后当你打电话时dlsym你可以这样做

SUPP_MESSAGES[0].write_func = dlsym(dlhandle, "symbol_name");

SUPP_MESSAGES[0].write_func然后将使用您的struct定义和函数指针指定的签名调用函数 poitnertypedef并记住它void *可以转换为任何类型的指针而无需强制转换,所以这就是您所需要的。

于 2015-02-20T19:34:33.313 回答
0

generate_basic_msg_ptr和朋友只是甚至没有初始化的变量(严格来说,它们可能已经初始化为零,但这可能不是你的意图)。所以它们没有编译时定义的值,显然不能用于数组初始化。您可能想要声明一个函数,如void func(<whatever>);, 并func在初始化中使用。

于 2015-02-20T19:32:20.980 回答