C结构函数指针 - 将自引用作为参数传递

时间:2014-03-18 09:47:19

标签: c struct arguments function-pointers self-reference

我想运行我的struct指向的函数并使用自动填充功能。

这是我正在努力的部分:

#include <stdio.h>
#include <stdlib.h>

struct Fra { //Fraction
  int n;     //Numerator
  int d;     //Denominator
  void (*p)(struct Fra*);
  void (*sD)(int, struct Fra*);
  void (*sN)(int, struct Fra*);
};

void print(struct Fra*);
void setDenom(int, struct Fra*);
void setNum(int, struct Fra*);

int main() {

  struct Fra* fraA = 0;

  fraA = (struct Fra*) malloc(sizeof(struct Fra));

  fraA->sN = setNum;
  fraA->sN(2, fraA);
  fraA->sD = setDenom;
  fraA->sD(3, fraA);
  fraA->p = print;
  fraA->p(fraA);

  return 0;
}

这就是我一直在努力实现的目标

自:

fraA->sN(2, fraA);
fraA->sD(3, fraA);
fraA->p(fraA);

要:

fraA->sN(2);
fraA->sD(3);
fraA->p();

在试错后花了一些时间,我得出的结论是我需要帮助。我尝试过浏览,但似乎我没有正确的关键字,因此我无法验证此问题是否为双重问题。

感谢您的帮助。

2 个答案:

答案 0 :(得分:2)

你可以声明一些宏来保存,总是传递正确的引用,这就是你能做的所有事情:

#define FRA_NEW(this, sN sD, sP) \
{ \
  (this) = calloc(sizeof(*(this))) \
  if (this) \
  { \
    (this)->sN = (sN); \
    (this)->sN = (sD); \
    (this)->sN = (sP); \
  } \
}

#define FR_DELETE(this) \
  free(this)

#define FRA_PRINT(this) \
  (this)->print(this)

#define FRA_SETNUM(this, num) \
  (this)->setNum(this, num)

#define FRA_SETDENOM(this, denom) \
  (this)->setDenom(this, denom)

我也建议让这个&#34;这个&#34;始终作为&#34;成员&#34; -functions的第一个参数。

int main(void) 
{
  struct Fra * fraA = NULL;

  FRA_NEW(fraA, setNum, setDenom, print);
  if (NULL == fraA)
  {
    perror("FRA_NEW() failed");
    return 1;
  }

  FRA_SETNUM(fraA, 2);
  FRA_SETDENOM(fraA, 3);
  FRA_PRINT(fraA);

  FRA_DELETE(fraA);

  return 0;
}

答案 1 :(得分:1)

我能想到的唯一真正有用的方法是提供完成工作的功能:

void call_print(struct Fra* fra)
{
    fra->p(fra);
}

void call_setDenom(int val, struct Fra* fra)
{
    fra->sD(val, fra);
}

void call_setNum(int val, struct Fra* fra);
{
    fra->sN(val, fra);
}

并使用这些:

call_setNum(2, fraA);
call_setDenom(3, fraA);
call_print(fraA);