写在前面
在用VS2015进行C语言编程时,写输入函数不能写成scanf
,而要写成scanf_s
,今天我将给大家解释为什么和怎么用。
为什么?
ANSI C中没有scanf_s()
,只有scanf(),scanf()
在读取时不检查边界,所以可能会造成内存访问越界,例如分配了5字节的空间但是读入了10字节。
char buf[5]={'\0'};
scanf("%s", buf);
如果输入1234567890,后面的部分会被写到别的空间上去。
以上代码如果用scanf_s
,第二行应改为scanf_s("%s",buf,5)
,表示最多读取4个字符,因为buf[4]
要放'\0'
。
scanf_s最后一个参数是缓冲区的大小,表示最多读取n-1个字符.
vc++2005/2008中提供了scanf_s(),在最新的VS2015中也提供了scanf_s()。在调用时,必须提供一个数字以表明最多读取多少位字符。
读取单个字符也需要限定长度:scanf_s("%c,%c",&c1,1,&c2,1);
而不能写成scanf_s("%c,%c",&c1, &c2,1, 1);
否则编译器会报错。