我想运行我的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();
在试错后花了一些时间,我得出的结论是我需要帮助。我尝试过浏览,但似乎我没有正确的关键字,因此我无法验证此问题是否为双重问题。
感谢您的帮助。
答案 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);