VS中scanf和scanf_s的问题及解决方法

在VS中写C语言程序的时候,有时候会碰到VS要求使用scanf_s的情况,这是因为scanf()在读取数据时不检查边界,所以可能会造成内存访问越界:

char buf[5]={0};
scanf("%s", buf);

这个时候,如果我们输入1234567,那么在5以后的部分就会被写到buf所指向内存空间后面的空间去,这就有可能造成内存访问越界,引起程序运行异常,而如果使用scanf_s函数就可以避免此问题的出现。

如果使用scanf_s则必须在后面添加一个参数n表示接收缓冲区的大小,例如

char buf[5]={0};
scanf("%s", buf,5);

表示最多读取4(5 - 1)个字符。

当然也可以让VS不进行这个检查,只需要在该文件前加入这三句话就可以

#define _CRT_SECURE_NO_WARNINGS
#define _CRT_SECURE_NO_DEPRECATE
#pragma warning(disable:4996);

猜你喜欢

转载自blog.csdn.net/qq_29769263/article/details/85331122