下面的代码会导致错误并杀死我的应用程序。这是有意义的,因为缓冲区只有10字节长,文本只有22字节长(缓冲区溢出)。
char buffer[10];
int length = sprintf_s( buffer, 10, "1234567890.1234567890." );
我如何捕捉这个错误,这样我就可以报告它,而不是崩溃我的应用程序?
编辑:
在阅读了下面的注释之后,我使用了_snprintf_s,如果它返回一个-1值,那么缓冲区就没有更新。
length = _snprintf_s( buffer, 10, 9, "123456789" );
printf( "1) Length=%d\n", length ); // Length == 9
length = _snprintf_s( buffer, 10, 9, "1234567890.1234567890." );
printf( "2) Length=%d\n", length ); // Length == -1
length = _snprintf_s( buffer, 10, 10, "1234567890.1234567890." );
printf( "3) Length=%d\n", length ); // Crash, it needs room for the NULL char
发布于 2009-10-01 19:43:55
来自MSDN:
sprintf_s和sprintf的另一个主要区别是,sprintf_s接受一个长度参数,指定以字符为单位的输出缓冲区的大小。如果缓冲区太小,无法打印文本,则将缓冲区设置为空字符串,并调用无效的参数处理程序。与snprintf不同,sprintf_s保证缓冲区将以空结束(除非缓冲区大小为零)。
因此,理想情况下,您所写的应该是正确的。
https://stackoverflow.com/questions/1505986
复制相似问题