在MSVC中,许多字符串函数提供了原始的、安全的版本和strsafe版本。例如,sprintf、sprintf_s和StringCchPrintf都是等效的,它们在安全性方面都有所提高(按某种度量标准)。
现在,我有一小段代码可以做到:
int bufsize = _vscwprintf(fmt, args) + 1;
std::vector<wchar_t> buffer(bufsize);
int len = _vsnwprintf_s(&buffer[0], bufsize, bufsize-1, fmt, args);分配正确大小的缓冲区。
在浏览strsafe函数时,我发现了一个用于_vsnwprintf_s的替代方法,但没有一个用于_vscwprintf的方法。对谷歌的检查似乎没有任何结果。
有没有一种strsafe的方法来编写我所缺少的代码,或者两者的替代函数,或者混合使用原始函数和strsafe函数是可以接受的?(在使用PREfast all rules的/w4上,不会给出关于当前方式的安全警告)
发布于 2011-11-16 07:59:39
_vscwprintf()只计算安全格式化字符串所需的wchar_t[]数组的大小,它实际上并不向缓冲区写入任何内容。因此,你不需要,也没有安全版本的函数。
https://stackoverflow.com/questions/8144771
复制相似问题