我试图解决问题*当我想在循环中获取用户输入时我会面对。 编辑*:问题是这个 - >清除缓冲区以读取下一个输入。
这容易出错吗?
#include <stdio.h>
int main(){
char buffer[10];
while(1){
fgets(buffer,10,stdin);
// use buffer for whatever i need... THEN!
*buffer = '\n';
}
}
编辑:这是我遇到错误的代码。没有分配到&#39; \ n&#39;我错了循环计数和输入。删除那些行没有错:/
#include <stdio.h>
#include <stdlib.h>
int main(){
int numbers[100];
int quant;
char buffer[10];
printf("how many numbers do i need to ask? MAX = 99\n");
fgets(buffer,10,stdin);
quant = atoi(buffer);
*buffer = '\n';
printf("%d times enter numbers! MAX 9 digit long !\n",quant);
for(int i=0;i<quant;i++){
printf("%d. number: ",i);
fgets(buffer,10,stdin);
numbers[i] = atoi(buffer);
*buffer = '\n';
}
printf("Numbers: \n");
for(int i=0;i<quant;i++){
printf("%d ",numbers[i]);
}
edit2:错误是基于内存溢出以及fgets如何处理输入。
#include <stdio.h>
int main(){
int ch;
char buffer[10];
for(int i=0; i<3; i++){
fgets(buffer,10,stdin);
printf("%s -- %d. time\n",buffer,i+1);
//while ((ch = getchar()) != '\n' && ch != EOF);
*buffer= '\n';
}
return 0;
}
如果我输入超过9位数作为输入(我意外地做了),跳转到下一个循环。如果我用while循环清除缓冲区则没有错误发生。 * buffer =&#39; \ n&#39;没用,意义......
答案 0 :(得分:1)
根据上下文,代码处理字符串。所以空(清除)缓冲区是一个包含空字符串的缓冲区。
所以你应该写
buffer[0] = '\0';
如果你的意思是函数fgets
读取一个空字符串,那么在这种情况下,一个空的(清除的)缓冲区可能看起来像
buffer[0] = '\n';
buffer[1] = '\0';
答案 1 :(得分:0)
它不容易出错#34;但它毫无意义。
&#34;清除&#34;中很少有任何一点。一个缓冲区,它从来没有明确定义什么&#34;清除&#34;装置
为什么您认为缓冲区需要被fget()
覆盖,而不管其内容是什么?如果行为令人困惑,您应该在依赖结果之前确保fgets()
成功。
答案 2 :(得分:0)
忽略您使用缓冲区的内容以及首先要清除缓冲区的原因:
如何清除缓冲区:
memset(buffer, 0, sizeof(buffer));