欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > > 文章正文

#define AT __FILE__ ":" TOSTRING(__LINE__),

来源: javaer 分享于  点击 7640 次 点评:45

#define AT __FILE__ ":" TOSTRING(__LINE__),


#define AT __FILE__ ":" TOSTRING(__LINE__)
有时候为了增加调试程序信息具体,加上:
#define STRINGIFY(x) #x
#define TOSTRING(x) STRINGIFY(x)
#define AT __FILE__ ":" TOSTRING(__LINE__)

example.c:
#include <stdio.h>
#define STRINGIFY(x) #x
#define TOSTRING(x) STRINGIFY(x)
#define AT __FILE__ ":" TOSTRING(__LINE__)
void error(const char *location, const char *msg)
{
  printf("Error at %s: %s\n", location, msg);
}
int main(int , char**)
{
  error(AT, "fake error");
  return 0;
}

运行结果: $./example
Error at example.c:12: fake error

相关文章

    暂无相关文章

用户点评