宏的高级使用

#define myprintf(...) printk("[lch]:File:%s, Line:%d, Function:%s," \  
     __VA_ARGS__, __FILE__, __LINE__ ,__FUNCTION__);  

1)VA_ARGS:总体来说就是将左边宏中 ... 的内容原样抄写在右边 VA_ARGS 所在的位置。

  1. FILE :宏在预编译时会替换成当前的源文件名
  2. LINE:宏在预编译时会替换成当前的行号
  3. FUNCTION:宏在预编译时会替换成当前的函数名称
    5)类似的宏还有 TIME,STDC, TIMESTAMP等,就完全当一个变量来使用即可。

你可能感兴趣的:(宏的高级使用)