c++ - 为日志记录提供回调的最佳方法是什么?

标签 c++

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

我想要的解决方案是:

  • 用户可以为日志定义回调。
  • 如果未定义回调,则使用 fprint。

所以我正在寻找具有默认定义的某种类型的静态函数,如果需要,我可以覆盖它。

这样做的最佳方法是什么? 由于我们不能重载静态函数,所以每个人都需要定义他们对日志记录函数的定义。

最佳答案

像这样:

typedef void (*logfuncp)(...);

logfuncp callbackfuncp = NULL;

void logfunction(...)
{
   if (callbackfuncp) 
       callbackfuncp(...);
   else
       fprintf(logfile, ...);
}


void setcustomlogfunction(logfuncp newcallback)
{
    callbackfuncp = newcallback;
}

应该可以。 ... 代表您的日志参数,当然可以是使用真正的 ... C 语法的可变参数,但不一定是。一切都取决于您的日志记录是什么。

关于c++ - 为日志记录提供回调的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14082476/

相关文章:

c++ - 如何在 C++ 中获取 char 的整数值?

c++ - 在 OpenCV 中使用多线程访问 Mat 是线程安全的吗?

c++ - 如何在 3D 中围绕同一枢轴/点旋转多个对象?

c++ - Eigen::Matrix 与 uchar 类型的 cv::Mat 之间的转换

c++ - 如何正确使用vector<uint8_t>.data()?

c++ - 用于检测将 wchar_t* 传递给 BSTR 的静态代码分析

c++ - 无需在 C++ 中复制即可使变量不可更改

c++ - 显示与main.cpp不同的类

c++ - 将字符地址存储到整数指针

c++ - 在我们的 c++ 程序中包含巨大的字符串?