使用代码如下:
char buff[256]
snprintf(buff, sizeof(buff), "%s 0x%02X", buff, array.at(i));
编译有如下警告:
warning: ‘ 0x’ directive output may be truncated writing 3 bytes into a region of size between 1 and 256
以上的snprintf因为格式化输出中%s将buff输出一次到字符串中,并且在字符串后又连接了“ 0x%02X”,还想再次放入buff中,
为了函数安全期间,将%s的内容删除。
假如当前buff的长度已经达到了buff最大长度,如果这时再追加“ 0x%02X”,必然会越界。
因为sizeof在运行之前,能够判断出buff的size,“ 0x%02X”也不会越界,考虑到安全,所以只打印了“ 0x%02X”内容。
##可能是使用的snprintf版本有问题,没有将snprintf的第二个参数应用好。