как создать массив указателей для вызова указателя функции?

#c

#c

Вопрос:

у меня есть код для массива указателя функции

 #include <stdio.h>

int sum(int a, int b);
int subtract(int a, int b);
int mul(int a, int b);
int div(int a, int b);

int (*p[4]) (int x, int y);

int main(void)
{
  int resu<
  int i, j, op;

  p[0] = sum; /* address of sum() */
  p[1] = subtract; /* address of subtract() */
  p[2] = mul; /* address of mul() */
  p[3] = div; /* address of div() */

  printf("Enter two numbers: ");
  scanf("%d %d", amp;i, amp;j);

  printf("0: Add, 1: Subtract, 2: Multiply, 3: Dividen");
  do {
    printf("Enter number of operation: ");
    scanf("%d", amp;op);
  } while(op<0 || op>3);

  result = (*p[op]) (i, j);
  printf("%d", result);

  return 0;
}

int sum(int a, int b)
{
  return a   b;
}

int subtract(int a, int b)
{
  return a - b;
}

int mul(int a, int b)
{
  return a * b;
}

int div(int a, int b)
{
  if(b) 
      return a / b;
  else 
      return 0;
}
  

код для массива указателей на функцию:

 #include <stdio.h>

int sum(int, int);
int product(int, int);
int subtract(int, int);

int main()
{
   int i = 0;
   int a = 10;
   int b = 5;
   int result = 0;
   int (*pfun[3])(int, int);

   pfun[0] = sum;
   pfun[1] = product;
   pfun[2] = subtract;

   for( i = 0 ; i < 3 ; i  )
   {
     result = pfun[i](a, b);
     printf("nresult = %d", result);
   }

   result = pfun[1](pfun[0](a, b), pfun[2](a, b));
   printf("nnThe product of the sum and the subtract = %dn",result);
}

int sum(int x, int y)
{
   return x   y;
}

int product(int x, int y)
{
   return x * y;
}

int subtract(int x, int y)
{
   return x - y;
}
  

теперь как объединить эти две программы. такой, что массив указателей, указывающих на указатели функции, и указатели функции могут иметь разное количество аргументов? есть предложения.

Комментарии:

1. Ты мне скажи! На каком языке вы пишете?

2. Тогда зачем вы написали тег C ?

Ответ №1:

Вам не только нужно хранить указатели на функции с переменным числом аргументов (это не очень сложно, например, вы могли бы использовать union ), но вам также нужно убедиться, что вы вызываете функции с правильным аргументом, а это немного сложнее, учитывая ваш дизайн.

Я предлагаю вместо этого использовать стек. Все ваши функции будут принимать стек только в качестве аргумента:

 void sum(stack_t *stack);
void subtract(stack_t *stack);
void product(stack_t *stack);
  

И ваш массив может быть объявлен таким образом:

 typedef void callback_t(stack_t *);

callback_t *p[] =
{
    sum,
    subtract,
    product,
    /* ... */
};
  

Тогда, например, sum было бы реализовано как таковое:

 void sum(stack_t *stack)
{
    if (depth(stack) < 2)
        perror("Not enough arguments in stack!");
    int b = popstack(stack);
    int a = popstack(stack);
    int c = a   b;
    pushstack(stack, c);
}
  

Но унарный минус был бы реализован таким образом:

 void neg(stack_t *stack)
{
    if (depth(stack) < 1)
        perror("Not enough arguments in stack!");
    int a = popstack(stack);
    pushstack(stack, -a);
}
  

Каждая функция сама решает, сколько аргументов ей нужно. Вызывающему не нужно знать.

Комментарии:

1. @thuk: Я не уверен, что понял вопрос, но я добавил то, что, по моему мнению, является необходимой вам информацией; скажите мне, если это то, что вы хотели.