3

我正在为 C++ 构建一个基于树的调试/日志系统。

它的“用户界面”是一个宏,它将用户定义的消息和调用站点信息(文件、行、对象地址)传递给特殊功能,然后执行日志记录。

该函数使用对象地址按对象实例对消息进行分组。

目前它看起来像这样:

// in logging system header
#define msg (event_level, message) \
    do_logging_ (event_level, __FILE__, __LINE__, this, message)

...

// in code
msg (MSG_WARNING, "some text");

我想问一下,是否有一些统一的方法(可在msg宏中使用)来NULL代替未定义的this位置(全局/静态函数)?this

4

2 回答 2

4

您可以更改宏定义:

#define msg (event_level, message, THIS) \
    do_logging_ (event_level, __FILE__, __LINE__, THIS, message)

用法:

msg (MSG_WARNING, "some text", this); // in member methods
msg (MSG_WARNING, "some text", NULL); // otherwise
于 2011-07-22T12:47:31.677 回答
1

我认为如果不修改您要记录的类中的代码,这是不可能的。但是,如果您愿意这样做,您可以从这样的模板派生所有需要日志记录功能的类:

    template <typename T>
    class loggable_class
    {
    protected:
        T* get_this() { return static_cast <T*> (this); }
    };

例如:

    class A : public loggable_class<A>
    {
        ...
    };

函数 get_this() 的附加全局定义将用于非成员函数:

    inline void* get_this()
    {
         return NULL;
    }

日志记录宏如下所示:

    #define msg (event_level, message) \
        do_logging_ (event_level, __FILE__, __LINE__, get_this(), message)
于 2011-07-22T13:11:29.033 回答