昨天给朋友写个小工具,其中 一环就是普通不过的输入整数。
简单的控制台程序用scanf("%d", &points);
写完之后专门用字母测试。
发现scanf 返回值为0,这个也正常,因为没有输入格式匹配的整数。
问题在于,scanf其实并没有成功读取到points。
如果不做处理,此时point将处于一个未知的状态,也就引入隐患。
所以对格式的校验又成了一个问题。
首先想到的自然是对scanf的返回值进行判断。
我判断返回值 count 是不是 = 0时,确实能检测到异常。
于是重新读取,代码如下:
while (true) {
printf("input points [< 10,000,000]: ");
count = scanf("%d", &points);
if (count == 0) {
printf("please input a integer.\n");
continue;
}
....
}
问题来了,发现再次执行scanf语句时并没有停止,而是一直循环。
猜测估计是因为刚才的输入没有读完,IO中还有数据。
于是加上一个gets()
while (true) {
printf("input points [< 10,000,000]: ");
count = scanf("%d", &points);
if (count == 0) {
printf("please input a integer.\n");
pbuf = gets(gs_buf);
continue;
}
...
}
可行。但这个办法显然不好。有没有清空io缓存的库函数。
很显然马上想到fflush(); 确实有用,测试代码:
while (true) {
printf("input points [< 10,000,000]:");
count = scanf("%d", &points);
if (count == 0) {
printf("please input a integer.\n");
fflush(stdin);
continue;
}
...
}
当然还有另外一个办法,先按照char[]读入,在转为int。
但是个人认为方法不好,scanf读入,需要考虑长度。
用scanf_s 又不跨平台。而且总觉得有点绕。
所以用scanf(“%d”, &points)后舍弃剩余数据是比较好的办法。
但是网上也有人说在gcc下fflush并不会把\n清除掉[点击查看]*
我没对gcc进行测试。