简单程序中的奇怪C错误(作业)

Jef*_*son 5 c io

下面是一些应该接受来自控制台的整数输入的简单代码.它一直正常工作,直到给出无效(非整数)输入.

 1 #include <stdio.h>
 2 
 3 int main()
 4 {
 5   int x = 0;
 6   int inp = 0;
 7   int nums[20]; 
 8   int idx = 0;
 9   for(;;){
10     printf("Enter an integer: ");
11     inp=scanf("%d", &x);
12     if(inp == 0){
13       printf("Error: not an integer\n");
14     }
15     else{
16       if(idx<20){
17         nums[idx] = x;
18         idx++;
19       }
20     } 
21   }
22   return 0;
23 }
Run Code Online (Sandbox Code Playgroud)

这是gdb的输出,显示我在输入值"g"后单步执行程序.看看它如何跳转到第18行,然后无法从用户那里寻找进一步的输入.

Starting program: /Users/jeffersonhudson/xxxx/hw1 
Enter an integer: g

Breakpoint 1, main () at hw1.c:12
12          if(inp == 0){
(gdb) n
13              printf("Error: not an integer\n");
(gdb) n
Error: not an integer
0x0000000100000ee4  18                  idx++;
(gdb) n
10          printf("Enter an integer: ");
(gdb) n
11          inp=scanf("%d", &x);
(gdb) n

Breakpoint 1, main () at hw1.c:12
12          if(inp == 0){
(gdb) 
Run Code Online (Sandbox Code Playgroud)

一旦你给它输入错误,这是程序的输出:

Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
Enter an integer: Error: not an integer
^C
Run Code Online (Sandbox Code Playgroud)

有人可以帮我弄清楚我在做错了吗?

i C*_*ood 7

在代码内部,当您检测到时if(inp == 0),这实际上意味着scanf()没有读取任何内容,因为它找到的第一个标记不是整数也不是空格.因此它没有在输入上前进,并且由你来丢弃它,否则它会一直卡住而不是读取任何东西.

使用scanf有两种简单的方法可以解决它:

1)当你检测到它时inp == 0,只需调用a scanf("%*s");即可丢弃字符串令牌.

2)将其读入char数组,并使用atoi(str)检索整数值.例如:

int idx = 0;
char aux[250]; // watchout for buffer overflows.
for(;;){
    printf("Enter an integer: ");
    scanf("%s", aux); // look at ways to avoid overflows here
    inp = atoi(aux);
    if(inp == 0 && aux[0] != '0'){
      printf("Error: not an integer\n");
    }
    ...
Run Code Online (Sandbox Code Playgroud)

但请注意,上面的第二个示例将处理输入,例如10abc值的整数10.如果您确实要强制执行,则可以快速扫描数据,不存在非整数字符.而且我认为这超出了你的作业范围,但你应该知道有关未来缓冲区溢出的问题:)