u013648963 2016-07-17 08:34 采纳率: 0%
浏览 875

log线程安全问题,请教解决办法

uint32_t log_level;

void log_debug(const char *format, ...);

#define LOG_DEBUG(format, ...) \
do { \
if (log_level & LOG_DEBUG) \
log_debug(format, VA_ARGS); \
} while (0)

LOG_DEBUG()宏可能被多个线程调用,在运行过程中用户可以通过web配置
log_level,但log_level是全局变量,这样log_level就不是线程安全,如果给
log_level加锁,那每次调用都要加锁。请问一下各位大神,有什么办法解决这种问题吗?
  • 写回答

1条回答 默认 最新

  • oyljerry 2016-07-17 13:12
    关注

    搞一个初始化函数 最开始调用来设置loglevel 不要多线程调用这样后面多线程写log就是都是读取loglevel就不需要加锁了

    评论

报告相同问题?

悬赏问题

  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分
  • ¥15 Macbookpro 连接热点正常上网,连接不了Wi-Fi。
  • ¥15 delphi webbrowser组件网页下拉菜单自动选择问题
  • ¥15 linux驱动,linux应用,多线程
  • ¥20 我要一个分身加定位两个功能的安卓app
  • ¥15 基于FOC驱动器,如何实现卡丁车下坡无阻力的遛坡的效果
  • ¥15 IAR程序莫名变量多重定义