0

让我们考虑这样的代码:

#include <stdio.h>
#include <stdarg.h>

#ifdef debug
#undef debug
#endif

#define debug(format, ...) tpk(format, __VA_ARGS__)

void tpk(const char* format, ...)
{
  const unsigned int len = 1024;
  char buffer[len];
  va_list args;

  va_start(args, format);
  vsprintf(buffer, format, args);
  va_end(args);

  printf(buffer);
}


int main()
{
  debug("No, you don't! ",  "But I do! %d %s\n", 34, "blabla");
  return 0;
}

需要考虑的事项:

我有一些代码要调试,这就是为什么我必须取消调试(请不要问我为什么,因为项目中包含标头的方式有点混乱)。

不要担心缓冲区溢出等,这仅用于调试目的。

什么不起作用:

我只收到No, you don't!消息,仅此而已。但是,如果我从消息中删除第一个参数,debug则会很好地打印出来。我在这里做错了什么?

更新:我犯了一个愚蠢的错误。我给出了一个格式字符串,它没有格式参数,因此一切正常。解决方案是修改函数:

#define debug(str, format, ...) tpk(str, format, __VA_ARGS__)

打印 str ,然后在格式上使用可变参数函数。

4

2 回答 2

2

在第一次调用debug函数中:

debug("No, you don't! ",  "But I do! %d %s\n", 34, "blabla");

第一个参数是formatvsprintf解析它并尝试找到替换的参数。由于"No, you don't!"不包含任何可替代的内容,其余参数将被忽略。

如果您删除该部分,"But I do! %d %s\n"包含%d并将%s被替换。

于 2013-07-18T11:15:26.277 回答
2

你说的和以下没有区别:

printf("No, you don't! ",  "But I do! %d %s\n", 34, "blabla");

你能看出这是做什么的吗?

提示:格式字符串是什么?

于 2013-07-18T11:02:23.483 回答