scanf()函数的详解以及使用时需要注意的一些细节 |
您所在的位置:网站首页 › 使用scanf输入数组 › scanf()函数的详解以及使用时需要注意的一些细节 |
这个函数原型不太好看出个所以然来,可以理解为(int scanf(“第一部分”, 第二部分)) 一般用法:int n = 0; char a[100] = {0}; scanf(“%n%s”, &n, a); scanf()函数的作用是从输入缓存区中读取若干个对应格式的数据。“第一部分”参数控制读取数据的个数以及类型,“第二部分”指明读取到数据后的存储位置。该函数在读取正常的时候返回需要读取的数据个数,不正常退出的时候返回已经读取到的数据个数。(关于返回值的问题,注意事项3里面有提及) scanf()函数的注意事项1scanf()函数是一个“不安全函数”所以使用的时候要注意内存的溢出问题。 至于什么是不安全函数,网上对于这个概念的解释很少。我简单说一下吧! 不安全函数就是“不帮助开发者防止内存溢出的函数”。 这句话是我自己总结的,本来我想找一些权威性一点的总结,但是没找到。虽然大家都知道有这个概念存在,但百度百科上面没有,我FQ到谷歌上面看了一下,也没有。或许不安全函数这个概念本身就是不存在的吧!只是人们喜欢这么称呼而已。因为一个函数它安不安全很多时候是和使用它的开发者有关的,即便是一个不安全的函数,我们也可以通过一些代码上面的约束使得它安全。安全和便捷一直都是把双刃剑。(与不安全函数相似的,还有信号安全函数和信号不安全函数,它们又是对于信号而已安不安全的函数了。) 我用一个例子来说明一下scabf()函数的不安全性吧!假设有如下代码: #include int main(void) { char s[1] = {0}; scanf("%s", s); printf("s:%s\n", s); return 0; }数组“s[1]”只能存储一个元素,但是如果我在scanf()函数要求输入阶段输入多于1个字符的字符串呢?会发生什么?答案是“什么事情都可能发生”。
在使用scanf()函数的时候,你输入的格式理论上必须和“第一部分”参数的格式相对应(后面有说明为什么是理论上)。 例如你代码是这样写的int n = 0; char s[100] = {0}; scanf("%n,%s", &n, s); 那么你输入的时候就必须要这样子输入: 11,abcdefg 当然,如果你什么格式都不写例如这样:scanf("%n%s", &n, s); 那么默认两个参数中间要用空格符(空格键)或者缩进(Tab键)或者回车符(回车键)隔开,一般用空格符。你就应该这样输入: 11 abcdefg 其实在没有格式的时候,有些情况下参数不用空格隔开,代码还是能正常运行的。 例如你代码是这样的: #include int main(void) { int n = 0; char s[100] = {0}; scanf("%d%s", &n, s); printf("n = %d\ts = %s\n", n, s); return 0; }而你的输入是这样的: 11abc 程序还是可以正常运行的:
scanf()函数在参数匹配的过程中,对于不匹配的类型,整个函数会直接退出,返回已经读取到的数据个数。 例如下面的例子: #include int main(void) { int a = 0, b = 0, c = 0; printf("返回值:%d\n", scanf("%d%d%d", &a, &b, &c)); printf("a = %d\tb = %d\tc = %d\n", a, b, c); return 0; }在这个例子中,如果你正常输入是没有问题的。
![]() ![]() ![]() 遇到再更新。。。 原博客始发于CSDN,在如今博客界的转载抄袭泛滥的环境下,原创不易,点个赞再走呗。以下是博客首页的链接。 零BUG是原则性问题。
|
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |