V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
luohao0414
V2EX  ›  C

c++log 打印

  •  
  •   luohao0414 · Aug 20, 2018 · 3917 views
    This topic created in 2813 days ago, the information mentioned may be changed or developed.

    C++能实现 java 注解自动在函数入口和出口打 log 的功能么?

    8 replies    2018-08-21 13:15:04 +08:00
    inoki
        1
    inoki  
       Aug 20, 2018 via Android
    任意参数的函数对象
    changnet
        2
    changnet  
       Aug 20, 2018 via Android
    一般是利用对象的构造和析构函数打印,然后封装成一个宏,在函数入口处调用。

    其他方式没见过,也不了解 java 的注解自动打印是什么样子的
    mmdsun
        3
    mmdsun  
       Aug 20, 2018 via Android
    不太了 c++解。c#支持 Attribute。相当于 Java 注解
    gnaggnoyil
        4
    gnaggnoyil  
       Aug 20, 2018
    GCC 有`-finstrument-functions`可以用来挂钩子,配合 libdl 可以做 symbol translation 和 demangle.

    其它 implementation 不清楚,不过无论如何这种需求都需要严重依赖于具体的 implementation,如果要在语言层面上正式直接实现这个需求,static reflection 加入标准之前想都别想
    chengluyu
        5
    chengluyu  
       Aug 20, 2018   ❤️ 1
    class AutoLogger {
    const char *funcName_;
    public:
    AutoLogger(const char *funcName) : funcName_{ funcName } {
    puts(funcName_);
    }
    ~AutoLogger() {
    puts(funcName_);
    }
    }

    然后定义一个宏,用 __func__ 初始化 AutoLogger:

    #define AUTO_LOGGER AutoLogger __you_will_never_use_this_name(__func__);

    在要记录的函数开头加上 AUTO_LOGGER 就行了。
    GeruzoniAnsasu
        6
    GeruzoniAnsasu  
       Aug 21, 2018 via Android
    RAII 了解一下
    类似 go 的 defer
    MeteorCat
        7
    MeteorCat  
       Aug 21, 2018 via Android
    看堆栈不就行了吗?
    cjw1115
        8
    cjw1115  
       Aug 21, 2018
    @MeteorCat log 还是非常有必要的,堆栈不是什么时候都能看的吧
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2509 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 47ms · UTC 07:50 · PVG 15:50 · LAX 00:50 · JFK 03:50
    ♥ Do have faith in what you're doing.