我正在为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
没有定义(全局/静态函数)?
发布于 2011-07-22 12:47:32
您可以更改宏定义:
#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-22 13:11:29
我认为如果不修改你的类中你想要记录的代码,这是不可能的。但是,如果你愿意这样做,你可以从一个模板中派生出你想要日志记录功能的所有类:
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)
https://stackoverflow.com/questions/6790175
复制相似问题