本人最近在Qt上开发程序时,应用程序在运行过程中crash,指针最后停在 svnprintf函数返回值指向的数组内容,debug 跟踪发现 vsnprintf 函数返回值远大于限制的字符长度 和 分配的buffer 长度。如下图:
查阅百度百科:
snprintf(),为函数原型int snprintf(char *str, size_t size, const char *format, ...)。
函数功能:
将可变个参数(...)按照format格式化成字符串,然后将其复制到str中
(1) 如果格式化后的字符串长度 < size,则将此字符串全部复制到str中,并给其后添加一个字符串结束符('\0');
(2) 如果格式化后的字符串长度 >= size,则只将其中的(size-1)个字符复制到str中,并给其后添加一个字符串结束符('\0'),返回值为欲写入的字符串长度。
函数返回值:

在Qt应用开发时遇到程序运行时崩溃,问题定位到svnprintf函数返回值超过预设缓冲区长度。调试显示vsnprintf返回值远大于限制的字符长度和分配的buffer长度,引发问题。
2244

被折叠的 条评论
为什么被折叠?



