当我们在VS中使用scanf()函数时,会遇到以下报错:
原因:
Many functions, member functions, template functions, and global variables in Visual Studio libraries are deprecated. Some, such as POSIX and Microsoft-specific functions, are deprecated because they now have a different preferred name. Some C runtime library functions are deprecated because they're insecure and have a more secure variant. Others are deprecated because they're obsolete. The deprecation messages usually include a suggested replacement for the deprecated function or global variable.
以下内容由机器翻译:
Visual Studio 库中的许多函数、成员函数、模板函数和全局变量已被弃用。 有些函数(例如 POSIX 和 Microsoft 特定的函数)已被弃用,因为它们现在具有不同的首选名称。 一些 C 语言运行库函数已被弃用,因为它们不安全并且具有更安全的变体。 其他的被弃用是因为它们已经过时了。弃用消息通常包括建议替换弃用的函数或全局变量。
因为scanf()函数在读取数据时不检查边界,所以可能会造成内存访问越界。有时黑客可以利用函数的不安全性黑掉系统。所以在Visual Studio中将其弃用并改用了更安全的变体scanf_s()函数。
例如:
char a[n];
scanf("%s", a);
//若输入超出容量的值,则超出的部分会溢出,从而可能会导程序运行异常。
char a[n];
scanf_s("%s", a, n);
//最多读取n-1个字符,因为a[n]要放'\0';
//若输入超出容量的值,则数组不会读到任何东西;
//scanf_s最后一个参数n是接收缓冲区的大小(即数组的容量)。
解决方法:
使用scanf_s()函数来代替scanf()函数。
网友评论