4

我有以下想法:

我有一个清除输入缓冲区的功能:

void clear_inputBuffer()
{
    char c;
    while ( (c = getchar()) != '\n' && c != EOF);
}

而不是为每个输入都写

scanf("%d", &selection);
clear_inputBuffer();

我想要一个包含两者的功能。像这样的东西:

int terminalInput(const char *format, ...) {
    int count = 0;
    va_list args;
    // Pass variable parameters
    va_start(args, format);
    count = scanf(format, args);
    va_end(args);

    clear_inputBuffer();
    return count;
}

该函数返回 1,但无论正确的输入是什么,“test”也返回 1。

int main(int argc, const char * argv[]) {
    int test;
    printf("number:");
    terminalInput("%d", &test);
    printf("Input: %d\n", test);

    return 0;
}

终端输出:

$ ./a.out
number:345
Input: 1
4

1 回答 1

4

您不能scanfva_list. 你需要vscanf改用。

另外,我不得不提一下,一般来说你应该几乎总是避免使用scanf/vscanf完全;众所周知,很难正确使用。相反,您应该使用(或如果可用)读取一行输入,然后在该行上使用。fgetsgetlinesscanf

于 2019-01-29T09:41:13.193 回答