为什么在 visual studio 2013/2015 之后出现 vsnprintf 崩溃?
Why following vsnprintf crash on visual studio 2013/2015?
#include <string>
#include <stdarg.h>
#include <stdio.h>
#include <memory>
void kekeTrace(const char* format, ...)
{
char buff[1000] = { 0 };
va_list argList;
va_start(argList, format);
vsnprintf(buff, 1000, format, argList);
va_end(argList);
}
int main()
{
std::shared_ptr<int> obj(new int(3));
kekeTrace("%x,%d,%s\n", obj, 1, "w"); //crash
kekeTrace("%x,%s\n", obj, "w"); // do not crash
return 0;
}
第一次调用 kekeTrace 会崩溃,但第二次调用不会。为什么?
这两行都是未定义的,因此它们可能会或可能不会崩溃,并且可能会或可能不会输出某些内容。
如今,编译器通常足够聪明,可以警告 printf
等格式字符串中不支持的类型,但由于您正在调用自己的函数,编译器不知道您要做什么有了它。
您需要传递底层指针:使用obj.get()
.
#include <string>
#include <stdarg.h>
#include <stdio.h>
#include <memory>
void kekeTrace(const char* format, ...)
{
char buff[1000] = { 0 };
va_list argList;
va_start(argList, format);
vsnprintf(buff, 1000, format, argList);
va_end(argList);
}
int main()
{
std::shared_ptr<int> obj(new int(3));
kekeTrace("%x,%d,%s\n", obj, 1, "w"); //crash
kekeTrace("%x,%s\n", obj, "w"); // do not crash
return 0;
}
第一次调用 kekeTrace 会崩溃,但第二次调用不会。为什么?
这两行都是未定义的,因此它们可能会或可能不会崩溃,并且可能会或可能不会输出某些内容。
如今,编译器通常足够聪明,可以警告 printf
等格式字符串中不支持的类型,但由于您正在调用自己的函数,编译器不知道您要做什么有了它。
您需要传递底层指针:使用obj.get()
.