C语言中对scanf与sscanf的理解

昵称:    振宇                     日期:2015年1月19日—2015年1月23日

1.本周已完成任务:本周对C语言的基本算法有一初步的温习与巩固。

2.本周未完成任务:还没有充足的掌握一些常用算法的自写与理解能力。

3.下周计划:学习C语言与其他有联系的知识,追求细节性问题,并从中真正受益。

4.关键技术点说明:

常见的scanf的含义与printf函数一样,都被定义在头文件stdio.h里,因此在使用scanf函数时要加上#include <stdio.h>。它是格式输入函数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。而sscanf()的含义是从一个字符串中读进与指定格式相符的数据。scanf用法想必已经被熟知,例如:scanf(“%d”,&x),这里值得注意的是它与scanf(“%d”,x)的区别,由于scanf函数是读取你输入的内容并把它存储到相应变量的地址里面,所以使用scanf时,变量前加&号。

scanf针对于单字符,且返回的是成功输入值的个数,而sscanf针对于字符串。

这里给出sscanf的常用例子:

1. 常见用法

char buf[512];

sscanf("123456","%s",buf);//此处buf是数组名,它的意思是将123456以%s的形式存入buf中!

printf("%s\n",buf);

结果为:123456

2. 取指定长度的字符串。如在下例中,取最大长度为4字节的字符串。

sscanf("123456","%4s",buf);

printf("%s\n",buf);

结果为:1234

3. 取到指定字符为止的字符串。如在下例中,取遇到任意小写字母为止的字符串

sscanf("123456abcdedf","%[^a-z]",buf);

printf("%s\n",buf);

结果为:123456

4. 取仅包含指定字符集的字符串。如在下例中,取仅包含1到9和小写字母的字符串。

sscanf("123456abcdedfBCDEF","%[1-9a-z]",buf);

printf("%s\n",buf);

结果为:123456abcdedf

当输入: sscanf("123456abcdedfBCDEF","%[1-9A-Z]",buf);

printf("%s\n",buf);

结果为:123456

5. 取到指定字符集为止的字符串。如在下例中,取遇到大写字母为止的字符串。

sscanf("123456abcdedfBCDEF","%[^A-Z]",buf);

printf("%s\n",buf);

结果为:123456abcdedf

6、给定一个字符串iios/12DDWDFF@122,获取 / 和 @ 之间的字符串,

先将"iios/"过滤掉,再将非'@'的一串内容送到buf中

sscanf("iios/12DDWDFF@122","%*[^/]/%[^@]",buf);

printf("%s\n",buf);

结果为:12DDWDFF

7、给定一个字符串“hello, world”,仅保留world。

(注意:“,”之后有一空格,%s遇空格停止,加*则是忽略第一个读到的字符串)

sscanf(“hello,world”,"%*s%s",buf);

printf("%s\n",buf);

结果为:world

%*s表示第一个匹配到的%s被过滤掉,即“hello,”被过滤了

如果没有空格则结果为NULL。
C语言,`scanf`函数用于从标准输入或其他指定位置读取数据,并按照格式化字符串解析输入。为了防止`scanf`导致错误并继续程序的执行,你可以采取以下几个步骤: 1. **检查是否成功读取**:`scanf`函数会返回实际匹配格式并读入的数据项个数,若为0,则表示未读取到任何内容,可能是格式错误、输入结束(EOF)或者用户按下Enter键。可以用`return 0;`或`if (scanf...)`提前退出,避免后续处理无效的输入。 ```c int count; if (scanf("%d", &count) == 1) { // 成功读取整数 } else { printf("Invalid input!\n"); return 1; // 或者选择跳过错误继续 } ``` 2. **使用宽字符(宽度)限制**:对于可能有多个匹配项的情况,指定每个字段的预期宽度可以帮助避免溢出。比如`scanf("%*[^0-9]%d"`,其`%*[^0-9]`会忽略所有非数字字符直到遇到下一个数字。 3. **错误处理和清理**:如果发生错误,可以清除错误状态标志,比如`ferror(stdin)`检查是否有错误发生,`clearerr(stdin)`清除错误和读取标记。还可以使用`getc()`来尝试获取下一个输入字符,直到遇到有效的输入或结束符。 4. **避免贪婪扫描**:贪婪扫描可能导致整个输入缓冲区都被读取,如果你只期望读取部分数据,应明确指定范围。 5. **考虑使用更安全的替代品**:对于复杂的输入验证需求,使用`fgets`再结合`sscanf`等函数可能会更安全,因为它们允许控制读取的字符数,不受输入流长度影响。 记住,总是测试边界情况,包括但不限于输入为空、超长输入以及非法格式的数据,以确保程序的健壮性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值