7*4 2018-11-02 01:07 采纳率: 50%
浏览 354

具有可变宏的 c 日志记录

I'm trying to write an overhead-free logging macro in C.

My first idea is:

#define debug_print(...) \
  { \
    printf(_LOG_FMT, _LOG_ARGS); \
    printf(__VA_ARGS__); \
    printf("\n"); \
  }

But this has the problem that I have to call printf three times (overhead).

My second idea is:

#define _LOGFUNCTION(LEVEL, message, ...) \
    printf(_LOG_FMT message "\n", _LOG_ARGS, __VA_ARGS__)

But now I can't pass it a simple string to log. It'll complain about zero arguments in VA_ARGS.

Is there a way to fix both of these problems?

Thanks a ton for your help!

转载于:https://stackoverflow.com/questions/53111416/c-logging-with-variadic-macros

  • 写回答

2条回答 默认 最新

  • elliott.david 2018-11-02 02:04
    关注

    Found the answer form the comment above!

    #define BAR_HELPER(fmt, ...) printf(fmt "\n%s", __VA_ARGS__)
    #define BAR(...) BAR_HELPER(__VA_ARGS__, "")
    

    https://stackoverflow.com/a/8673872/5531233

    Thanks again Some programmer dude!

    评论

报告相同问题?

悬赏问题

  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计