歌者文明清理员 发表于 2023-7-2 23:31:13

c语言,goto

code:
#include <stdlib.h>
#include <stdio.h>

int main() {
    int code;
    printf("欢迎游玩游戏\n");
cd1:printf("请输入指令代码(1.获取帮助 2.开始游玩):");
    scanf("%i", &code);
    if (code != 1 && code != 2) goto cd1;
    return 0;
}

如果指令代码不正确,也就是说不是1且不是2我就让程序重新运行到cd1的位置
但为什么停不下来了?是scanf直接停下了吗,因为code里已经有值了
如何解决?

isdkz 发表于 2023-7-2 23:33:34

您的代码有一些问题。您在程序中使用scanf函数来从用户那里接收输入。如果用户输入了非整数(如字符串或字符)时, scanf函数将失败,并且会保留输入缓冲区中的错误数据。然后,下一次循环时,该错误数据会再次被scanf读取,导致循环无法停止。

解决此问题的一种方法是在每次scanf后清除输入缓冲区。下面是修改后的代码:

#include <stdlib.h>
#include <stdio.h>

int main() {
    int code;
    printf("欢迎游玩游戏\n");
cd1:printf("请输入指令代码(1.获取帮助 2.开始游玩):");
    int status = scanf("%i", &code);
    if(status != 1) {// 输入的不是整数
      int c;
      while ((c = getchar()) != '\n' && c != EOF);// 清除输入缓冲区
      goto cd1;
    }
    if (code != 1 && code != 2) goto cd1;
    return 0;
}


这段代码中, getchar会逐个读取并清除输入缓冲区中的所有字符,直到遇到换行符或文件结束符。这样可以防止由于错误输入导致的循环。

另一种更好的选择是尽量避免使用goto ,因为goto可能会让程序的控制流程变得难以理解。可以使用while循环或者其他循环结构来替代goto 。例如:

#include <stdlib.h>
#include <stdio.h>

int main() {
    int code;
    printf("欢迎游玩游戏\n");
    int status;
    do {
      printf("请输入指令代码(1.获取帮助 2.开始游玩):");
      status = scanf("%i", &code);
      if(status != 1) {// 输入的不是整数
            int c;
            while ((c = getchar()) != '\n' && c != EOF);// 清除输入缓冲区
      }
    } while(status != 1 || (code != 1 && code != 2));
    return 0;
}


在这段代码中,如果用户的输入不是一个整数,或者输入的整数不是1也不是2,程序会不断循环直到用户输入一个合适的整数。

歌者文明清理员 发表于 2023-7-3 00:24:40

isdkz 发表于 2023-7-2 23:33
您的代码有一些问题。您在程序中使用scanf函数来从用户那里接收输入。如果用户输入了非整数(如字符串 ...

#include <stdlib.h>
#include <stdio.h>

int main() {
    int code;
    printf("欢迎游玩游戏\n");
    int status;
    do {
      printf("请输入指令代码(1.获取帮助 2.开始游玩):");
      status = scanf("%i", &code);
      fflush(stdin);
    } while(code != 1 && code != 2);
    return 0;
}

https://blog.csdn.net/weixin_45691686/article/details/104873575
可以吗
页: [1]
查看完整版本: c语言,goto