У меня есть набор функций для вызова
e.g.:
void void_func(); /* id = 0 */
void void_func1(int); /* id = 1 */
void void_func2(int, char *); /* id = 2 */
void void_func3(short int); /* id = 3 */
int int_func(); /* id = 4 */
int int_func1(int); /* id = 5 */
int int_func2(float); /* id = 6 */
int int_func3(int, int *); /* id = 7 */
char *char_func(); /* id = 8 */
char *char_func1(int); /* id = 9 */
char *char_func2(int, int); /* id = 10*/
void enum_func(enum_t); /* id = 11*/
enum_t enum_func1(int *, int); /* id = 12*/
enum_t enum_func2(); /* id = 13*/
Я определил следующие указатели функций и параметры для вызова любой из вышеперечисленных функций:
typedef void * (*funcptr)();
typedef void * (*funcptr1)(void *);
typedef void * (*funcptr2)(void *, void *);
void * parameter1;
void * parameter2;
void * return_param;
Я определил пользовательскую структуру для вызова всех функций:
typedef struct funcid {
int id;
funcptr f0;
funcptr1 f1;
funcptr2 f2;
void * param1;
void * param2;
void * ret_param;
} func_id;
Я инициализировал структуру, как показано ниже, на основе идентификатора (в любое время вызывается только одна из вышеуказанных функций):
func_id func_str[] = {
/* { id, f0 , f1 , f2 , param1 , param2 , ret_param } ,*/
{ 0 , &void_func , NULL , NULL , (void *)parameter1 , (void *)parameter2 , (void *)return_param } ,
{ 1 , NULL , &void_func1 , NULL , (int *)parameter1 , (void *)parameter2 , (void *)return_param } ,
{ 2 , NULL , NULL , &void_func2 , (int *)parameter1 , (char *)parameter2 , (void *)return_param } ,
{ 3 , NULL , &void_func3 , NULL , (short int *)parameter1 , (void *)parameter2 , (void *)return_param } ,
{ 4 , &int_func , NULL , NULL , (void *)parameter1 , (void *)parameter2 , (int *)return_param } ,
{ 5 , NULL , &int_func1 , NULL , (int *)parameter1 , (void *)parameter2 , (int *)return_param } ,
{ 6 , NULL , &int_func2 , NULL , (float*)parameter1 , (void *)parameter2 , (int *)return_param } ,
{ 7 , NULL , NULL , &int_func3 , (int *)parameter1 , (int *)parameter2 , (int *)return_param } ,
{ 8 , &char_func , NULL , NULL , (void *)parameter1 , (void *)parameter2 , (char *)return_param } ,
{ 9 , NULL , &char_func1 , NULL , (int *)parameter1 , (void *)parameter2 , (char *)return_param } ,
{ 10, NULL , NULL , &char_func2 , (int *)parameter1 , (int *)parameter2 , (char *)return_param } ,
{ 11, &enum_func , NULL , NULL , (enum_t *)parameter1 , (void *)parameter2 , (void *)return_param } ,
{ 12, NULL , NULL , &enum_func1 , (int *)parameter1 , (int *)parameter2 , (enum_t *)return_param } ,
{ 13, &enum_func2 , NULL , NULL , (str1 *)parameter1 , (void *)parameter2 , (enum_t *)return_param }
};
Теперь в выражении case switch я пытаюсь вызвать любую из функций:
printf("\nEnter Number of parameters of functions : ");
scanf("%d", ptr1);
printf("\nEnter whether the function has a return value (0/1) : ");
scanf("%d", &ret);
printf("\nWhich function to execute (function id): ");
scanf("%d", &var1);
if (*ptr1 > 0)
printf("\nEnter the Parameters : \n");
func_id current_func;
for (i=0; i<13; i++){
if (func_str[i].id == var1) {
current_func = func_str[i];
break;
}
}
switch(*ptr1) {
case 0: {
if (ret == 1) {
printf("\nEntering case 0\n");
current_func.ret_param = (*current_func.f0)();
}
else {
(*current_func.f0)();
}
break;
}
/* In actual case the parameters would be read from a memory location and the address of that can be stored in parameter1 */
case 1: {
printf("\nEnter Parameter 1: ");
scanf("%d", parameter1);
printf("\nParameter 1 = %d\n",*(int *)parameter1);
if (ret == 1) {
current_func.ret_param = (*current_func.f1)(current_func.param1);
}
else {
(*current_func.f1)(current_func.param1);
}
break;
}
/* In actual case the parameters would be written in a memory location and the address of that can be stored in parameter1 and parameter2 */
case 2: {
printf("\nEnter Parameter 1: ");
scanf("%d", parameter1);
printf("\nEnter Parameter 2: ");
scanf("%d", parameter2);
if (ret == 1) {
current_func.ret_param = (*current_func.f2)(current_func.param1, current_func.param2);
printf("\nReturned parameter : current_func.ret_param = %d", *(int *)current_func.ret_param);
}
else {
(*current_func.f2)(current_func.param1, current_func.param2);
}
break;
}
default:
printf("ERROR");
}
В действительности, параметры записываются в ячейку памяти, адрес которой будет назначен с соответствующим типом данных в структуре инициализации.
Но проблема, с которой я сталкиваюсь, связана с типами данных параметров, которые должны быть переданы / возвращены при вызове функций. Таким образом, существует ли механизм для такой установки, где можно вызывать любую функцию, основанную на количестве параметров любого типа данных.
Ценю помощь в этом отношении.