我有第三方库,它调用宏进行日志记录。在宏中,他们使用fprintf进行日志记录。 我正在考虑修改代码以定义用于日志记录的自定义回调,但我不确定什么是最好的方法。
我想要的解决方案是:
所以我正在寻找一些默认定义的静态函数,如果需要我可以覆盖它。
这样做的最佳方法是什么? 因为我们不能重载静态函数所以每个人都需要定义日志函数的定义。
答案 0 :(得分:1)
这样的事情:
typedef void (*logfuncp)(...);
logfuncp callbackfuncp = NULL;
void logfunction(...)
{
if (callbackfuncp)
callbackfuncp(...);
else
fprintf(logfile, ...);
}
void setcustomlogfunction(logfuncp newcallback)
{
callbackfuncp = newcallback;
}
应该有效。 ...
表示您的日志记录参数,当然可以使用真正的...
C语法进行var-args,但不一定是。一切都取决于您的日志记录。
答案 1 :(得分:0)
上次遇到类似问题时,我使用了函数指针。
让记录器使用函数指针调用函数。
默认情况下,将指针设置为默认方法(调用fprintf)。
如果用户想要覆盖该行为,他们将使用自己的功能。
....只是另一种解决方案