可以从指针数组中的值初始化指针吗?

问题描述 投票:0回答:1

我基本上想要一个函数列表作为函数指针数组;然后我想管理该数组中的索引变量和接受该数组中的值的指针变量。考虑下面的 C 代码来说明这一点,它编译得很好:

#include <stdio.h>

void func_01() {
    printf("func_01\n");
}
void func_02() {
    printf("func_02\n");
}
void func_03() {
    printf("func_02\n");
}

enum func_choice_e {
    eFUNC01 = 0,
    eFUNC02 = 1,
    eFUNC03 = 2,
#define _NUM_FUNC_CHOICE 3
    NUM_FUNC_CHOICE = _NUM_FUNC_CHOICE,
};
typedef enum func_choice_e func_choice_t;

void* funcs_ptrs[_NUM_FUNC_CHOICE] = {
    &func_01,
    &func_02,
    &func_03,
};

func_choice_t my_func_choice_idx = eFUNC01;
void* my_func_choice_ptr = &func_01;

int main()
{
    my_func_choice_idx = eFUNC02;
    my_func_choice_ptr = funcs_ptrs[my_func_choice_idx];
    printf("Hello World %p\n", my_func_choice_ptr);

    return 0;
}

如上面的代码所示,在代码中我可以通过索引变量设置指针变量(

my_func_choice_ptr = funcs_ptrs[my_func_choice_idx];
)。

但是,我想做类似的事情,也用于初始化 - 最终,我只想先手动初始化数组值和

my_func_choice_idx
- 然后将指针自动初始化为相应的
my_func_choice_idx
数组中的第 th 元素;所以而不是工作指针初始化器:

void* my_func_choice_ptr = &func_01;

...我已经尝试过这些:

//void* my_func_choice_ptr = funcs_ptrs[my_func_choice_idx]; // error: initializer element is not constant
//void* my_func_choice_ptr = funcs_ptrs[eFUNC01]; // error: initializer element is not constant
//void* my_func_choice_ptr = funcs_ptrs[0]; // error: initializer element is not constant

...正如评论中的错误消息所暗示的那样,这些都不起作用。

我有点明白为什么

funcs_ptrs[my_func_choice_idx]
可能会失败 -
my_func_choice_idx
毕竟是一个变量 - 但当编译器到达
my_func_choice_ptr = funcs_ptrs[0];
时,它应该已经“知道”了地址、大小和初始值
funcs_ptrs
-> 所以我不明白为什么它不能将
my_func_choice_ptr
设置为
funcs_ptrs
的第一个条目?!

那么 - 是否有一些语法可以用于初始化,这将允许我将指针变量初始化到数组中条目的给定初始值(类似于在正常代码中工作的赋值

my_func_choice_ptr = funcs_ptrs[my_func_choice_idx];
)?

arrays c pointers initialization
1个回答
1
投票

您声明的函数指针是错误的。函数指针不是

void*
但需要有正确的签名:

typedef void(*func_ptr)(void);

然后您可以像这样使用:

func_ptr funcs_ptrs[_NUM_FUNC_CHOICE] = {
    &func_01,
    &func_02,
    &func_03,
};

func_ptr my_func_choice_ptr = &func_01;
© www.soinside.com 2019 - 2024. All rights reserved.