我刚刚完成了C编程语言第二版(K&R)一书中的练习6.1,下面是练习题:
我们的getword版本不能正确处理下划线、字符串常量,
注释或预处理器控制行。写一个更好的版本。
这是书中的getword函数:


    int getword(char *word, int lim)
    {
        int c;
        char *w = word;
        while (isspace(c = getch()))
            ;
        if (c != EOF)
            *w++ = c;
        if (!isalpha(c)) {
            *w = '\0';
            return c;
        }
        for ( ; --lim > 0; w++)
            if (!isalnum(*w = getch())) {
                ungetch(*w);
                break;
            }
        *w = '\0';
        return word[0];
    }


函数调用main():

    while (getword(word, MAXWORD) != EOF) {...}

这是我的getword函数:
int getword(char *word, int lim)
{
    int c, c1;
    char *w = word;
    while (isspace(c = getch()))
        ;
    if (c != EOF)
        *w++ = c;
    else
        return EOF;
   // handle comments: /* */
    if ( c == '/') {
        if ((c1 = getch()) == '*') {
            keytab[31].count++;
            int ok = 1;
            while (ok) {
                // skip characters in comment lines
                while ((c = getch()) != EOF || c != '*')
                    ;
                if (c == EOF)
                    return EOF;
                if ((c = getch()) == '/')
                    ok = 0;
            }
            return COMMENT;
        }
         // handle comments : //
        else if (c1 == '/') {
            keytab[32].count++;
            while ((c = getch()) != EOF || c != '\n')
                ;
            if (c == EOF)
                return EOF;
            return COMMENT;
        }
        else
            return c;
    }
    // handle preprocessor control lines, start with '#'
    if (c == '#') {
        keytab[34].count++;
        while ((c = getch()) != EOF || c != '\n')
            ;
        if (c == EOF)
            return EOF;
        return '#';
    }
    // handle string constants, " "
    else if (c == '\"') {
        while ((c1 = getch()) != EOF || c1 != '\"')
            ;
        if (c1 == EOF)
            return EOF;
        keytab[33].count++;
        return CONSTANT;
    }
    else if (c != '_' && !isalpha(c)) {
        while ((c = getch()) != EOF && !isspace(c))
            ;
        if (c == EOF)
            return EOF;
        return NOT;
    }
    // c is '_' or letter , scan characters until EOF or space, or punctuation
    // to get a complete word
    for ( ; --lim > 0; w++)
        if ((*w = getch()) == EOF || isspace(*w) || ispunct(*w)) {
            ungetch(*w);
            break;
        }
    *w = '\0';
    return WORD;
}

如果我不输入“,//,/*或#”,代码将正常运行,我可以通过输入ctrl+d来停止输入。但是一旦我输入上述字符之一,程序就无法读取EOF,因此我无法停止输入。我用gdb调试程序,但还是没有得到它。那会发生什么呢?

最佳答案

&&||

while ((c = getch()) != EOF || c != '*')

以上都是真的。
也许
while ((c = getch()) != EOF && c != '*')

09-04 16:12