回调记录的最佳方法是什么?

时间:2012-12-29 14:17:17

标签: c++

我有第三方库,它调用宏进行日志记录。在宏中,他们使用fprintf进行日志记录。 我正在考虑修改代码以定义用于日志记录的自定义回调,但我不确定什么是最好的方法。

我想要的解决方案是:

  • 用户可以定义回调以进行记录。
  • 如果没有定义回调,请使用fprint。

所以我正在寻找一些默认定义的静态函数,如果需要我可以覆盖它。

这样做的最佳方法是什么? 因为我们不能重载静态函数所以每个人都需要定义日志函数的定义。

2 个答案:

答案 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)。

如果用户想要覆盖该行为,他们将使用自己的功能。

....只是另一种解决方案