EOF上出现意外的fgets行为

时间:2013-03-29 21:29:44

标签: c eof fgets

我有这个代码从stdin获取一行:

char string[USR_SIZE+1];
/*USR_SIZE is 9 */ 
fgets(string, USR_SIZE, stdin);
size_t len = strlen(string);
if (string[len-1] == '\n') {
    // read in whole line, no need to clear buffer
    string[len-1] = 0;
}    
else {
    if(feof(stdin)){
        printf("EXACT LEN\n");
    }
    else{
        //username too long, clear stdin and retry
        printf("Dumping...");
        dump_line(stdin); //clear stdin
        /*something that loops until success*/

    }

}

缓冲区string中没有换行符表示EOF或字符串已被剪切。

现在。所需的最佳字符串类似于"user_123"(8个字符)。现在,如果我输入"user_12345678",它只能正确存储"user_123"并执行else主体。如果我输入"user_123",它也会执行其他正文。

我想区分"user_123"EOF)字符串与"user_1234"(cutted),因为仅在最后一种情况下输入不正确。为什么没有设置feof

此外:我如何检查fgets错误管理的返回值?

找到了这个解决方案:

if (fgets(string, USR_SIZE + 1, stdin)){
    if (strlen(string) == USR_SIZE && string[USR_SIZE - 1] == '\n'){
        printf("EXACT\n");
        /* User entered an eight character string. */
        string[USR_SIZE - 1] = 0;
    }
    else{
        if(strlen(string) < USR_SIZE-1){
        printf("INVALID<<<\n");
        /*don't dump*/
    }
        else{
            printf("INVALID>>>\n");
            dump_line(stdin);
        }
    }

    printf("EXIT\n");
    printf("%s\n", string);
}
else{
    free(auth_data);
    EXIT_ON_ERROR_("Error while getting user input\n");
}

1 个答案:

答案 0 :(得分:0)

如果你想允许8个字符和EOF以及换行符,这样的东西会起作用:

char buf[10];
fgets(buf, 10, stdin);

int len=strlen(buf);
if (buf[len-1] == '\n') buf[len-1] = '\0';
if (strlen(buf) == 8)
    puts("Correct length");
else
    puts("Incorrect length");

fgets未在此示例中测试成功)