scanf()和scanf_s()

在最初的C语言中,原版的输入就是scanf("<格式化字符串>",<地址表>)

ANSI C中没有scanf_s(),只有scanf(),scanf()在读取时不检查边界,所以可能会造成内存访问越界,例如分配了5字节的空间但是读入了10字节
  1. char buf[5]={''};
  2. scanf("%s", buf);
    如果输入1234567890,后面的部分会被写到别的空间上去。
    以上代码如果用scanf_s,第二行应改为scanf_s("%s",buf,5),表示最多读取4个字符,因为buf[4]要放''
scanf_s最后一个参数是缓冲区的大小,表示最多读取n-1个字符。
 
当然在使用这个方法时,并不需要添加新的头文件,只需要#include<stdio.h>即可.
原文地址:https://www.cnblogs.com/ouyang_wsgwz/p/6912025.html