首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
拉钩
V2EX  ›  C/C++/Obj-C

C++ 新手入门,写了一个简单的 log 小工具,顺便请教个小问题。

  •  
  •   Aidenboss · 7 天前 · 568 次点击

    C++ 新手,写了一个简单的 log 小工具。
    使用了 appender、format 正交设计。支持多个 appender。appender 只实现了 FileLoggerAppender 和 ConsoleLoggerAppender ; format 只实现了 PlainTextFormat。
    还简单的支持 template 参数。 使用方式:

       auto_ptr<Logger> logger(new Logger());
       auto_ptr<LoggerAppender> fileLoggerAppender(new FileLoggerAppender());
       auto_ptr<LoggerAppender> consoleLoggerAppender(new ConsoleLoggerAppender());
       auto_ptr<PlainTextLoggerFormat> plainTextLoggerFormat(new PlainTextLoggerFormat());
       logger.get()->loggerAppender(fileLoggerAppender.get())
               ->loggerAppender(consoleLoggerAppender.get())
               ->loggerFormat(plainTextLoggerFormat.get());
    
       string errorMessage("num1: {} add number2: {}, sum : {}");
    
       logger.get()->e(errorMessage, "10", "20", "30");
    

    output:

        [ERROR] 2018-12-2 23:41:40: num1: 10 add number2: 20, sum : 30
    

    还有一个小问题,想请教下。

    num1: {} add number2: {}, sum : {}
    

    只能传入 10, 20, 30 的字符串,而不能传入 int 类型的参数。 我这里使用了 va_args 的实现,不能直接判断参数类型。不知道大神们有没有其他方式实现呢?
    谢谢解疑。

        1
    Hconk   7 天前 via Android
    变参模板了解下
        2
    zmj1316   7 天前
    线程安全做了吗?
        3
    winterfell30   7 天前
    同楼上,不过楼主为什么要用 auto_ptr,而不用更安全的 unique_ptr
        4
    zmj1316   7 天前
    转字符串的话,用 fold + std::to_string 就行了
        5
    htfy96   7 天前
    1. 现在都用 shared_ptr 和 make_unique 与变参模板了
    2. 需要增加宏或者 file_location 来提供打印文件名行号的功能
    3. format 直接用 fmt 库吧
        6
    Aidenboss   7 天前
    @Hconk @zmj1316 @winterfell30 @htfy96
    谢谢各位老师的解疑。过会我会按照老师提出的建议做出一定的修正。
    再次谢谢!
        7
    Wicked   7 天前
    GitHub 上看下别人的实现?
    stream style 可以看 NanoLog
    printf style 可以看[stb_log]( https://github.com/wangyongcong/stb_log)
    C++14 single file logger,比 NanoLog 还快那么一点点。你可以跳过多线程的部分,看一下参数处理。用的是比较流行的模板变参的做法,最小化 frondend 的延迟。
        8
    misaka19000   7 天前 via Android
    赞👍 学习了
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   960 人在线   最高记录 4019   ·  
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.1 · 17ms · UTC 17:53 · PVG 01:53 · LAX 09:53 · JFK 12:53
    ♥ Do have faith in what you're doing.
    沪ICP备16043287号-1