6

为什么对andfflush(..)不起作用? 如果我使用声明并且它有效,但不起作用,我尝试放在不同的地方但它不起作用,我在 ubuntu 13.04 中使用代码块;c2c0
c0 = 0c2 = 0fflush(stdin)

int main(void)
{
    int cod ,passou = 0, c0, c1, c2, c3, ct;
    float p1, p2, p3;
    char o;

    do {
    puts  ("Informe codigo: ");
    scanf ("%i", &cod);
    fflush (stdin);
        switch (cod)
        {
            case 0:
                c0 = c0 + 1;
                break;

            case 1:
                c1 = c1 + 1;
                ct = ct + 1;
                break;

            case 2:
                c2 = c2 + 1;
                ct = ct + 1;
                break;

            case 3:
                c3 = c3 + 1;
                ct = ct + 1;
                break;

            default:
                puts ("Valor invalido");

        }
        getchar();
        puts ("Deseja informar mais um voto?");
        fflush (stdin);
        scanf("%c",&o);
        if (o == 'S' || o == 's' ) {
        passou = 0;
        } else if (o == 'N' || o == 'n' ) {
        passou = 1;
        } else {
        puts ("Opcao invalida");
        }
        } while ( passou != 1 );


        p1=(c1/ct)*100;
        p2=(c2/ct)*100;
        p3=(c3/ct)*100;
        if (c1 > c2 && c1 > c3 && c1 > c0 ) {
        puts ("Candidato numero 1 eh o vencedor");
        } else if (c2 > c1 && c2 > c3 && c3 > c0) {
        puts ("Candidato numero 2 eh o vencedor");
        } else if (c3 > c1 && c3 > c2 && c3 > c0) {
        puts ("Candidato numero 3 eh o vencedor");
        } else {
        puts ("Numero de votos em branco eh maior do que todos os outros candidatos");
        }
        printf ("\nTotal de votos do candidato 1: %d", c1);
        printf ("\nTotal de votos do candidato 2: %d", c2);
        printf ("\nTotal de votos do candidato 3: %d", c3);
        printf ("\nTotal de votos em branco: %d", c0);
        printf ("\nPercentual de votos do candidato 1: %.2f", p1);
        printf ("\nPercentual de votos do candidato 2: %.2f", p2);
        printf ("\nPercentual de votos do candidato 3: %.2f", p3);

        return 1;
    }
4

2 回答 2

4

在您的系统 ubuntu 13.04(Unix 或 Linux)上,调用 fflush (stdin);是未定义的行为!

int fflush(FILE *ostream);

ostream 指向未输入最近操作的输出流或更新流, fflush 函数会导致该流的任何未写入数据被传递到主机环境以写入文件;否则,行为未定义

要学习正确刷新输入缓冲区的技巧,您可以使用以下一些代码片段,它们实际上从输入缓冲区读取和丢弃不需要的字符。您可以在读取实际数据之前将其用作 fflush。阅读此常见问题解答条目。

对于C

 while ((ch = getchar()) != '\n' && ch != EOF);  

对于C++

 while ((ch = cin.get()) != '\n' && ch != EOF);

但是,如果您在输入流中没有数据时调用这些,程序将等待直到有数据,这会给您带来不希望的结果。

阅读:@Keith Thompson的回答:“C 库函数的替代方案fflush(stdin)

编辑:
有些平台fflush(stdin)是完全定义的(作为该平台上的非标准扩展)。主要的例子是一个众所周知的系统家族,统称为 Windows。微软的规格:

刷新流

int fflush(FILE *stream )函数刷新流。如果与流关联的文件已打开以供输出,fflush则将与流关联的缓冲区的内容写入该文件。如果流对 开放 input,则fflush清除缓冲区的内容。 fflush否定之前对 ungetc 的任何调用对流的影响。此外,fflush(NULL) 刷新所有为输出打开的流。通话后流保持打开状态。fflush 对无缓冲的流没有影响。

于 2013-05-25T18:40:40.757 回答
2

fflush(stdin)具有未定义的行为。从此以后使用它来处理使用时保留在stdin缓冲区中的换行符scanf(),特别是在您需要读取字符但缓冲区中剩余的换行符被自动占用为字符的情况下:

 while((c = getchar()) != '\n' && c != EOF);

这就是cplusplusreference所说的fflush()(您也可以从其他来源验证相同的内容,因为这里有太多退伍军人因此皱眉,cplusplusreference尽管他们没有完全谴责它)

......In some implementations, flushing a stream open for reading causes its input buffer to be cleared (but this is not portable expected behavior).....

http://www.cplusplus.com/reference/cstdio/fflush/

于 2013-05-25T18:43:22.107 回答