马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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里已经有值了
如何解决?
您的代码有一些问题。您在程序中使用 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,程序会不断循环直到用户输入一个合适的整数。
|