当我们在查找问题调试代码时,相当一部分难题是找到正确的调用位置,根据程序上下文理解代码。如何才能快速找到调用位置呢?有经验的同学一定会说“你不会看堆栈吗?”,对看堆栈可以看到调用位置,但在一些特殊情况下是不能通过堆栈看到的,比如何在Release版本下……;那怎么办呢?这时__FILE__,__LINE__就可以出场了;
__FILE__ 宏表示当前代码所在文件名
__LINE__宏表示当前代码所在行;
我们在定义函数时增加这两个参数就可以做到任何时候都能知道调用代码的所在文件及代码行了;
这就完了吗?这时又有新问题了,每次都要多写两个参数也很麻烦啊,那怎么办?看代码:
#ifdef _MSC_VER
#define doCommand(_type,...) _doCommand(FILE,LINE,_type,##VA_ARGS)
#else
#define doCommand(...) _doCommand(FILE,LINE,VA_ARGS)
#endif
像上面代码,很多地主都需要调用doCommand函数,如果给它增加了参数,那调用时会很不方便,这时我们定义一个宏,给它“增加一层”,完美解决问题