我刚刚完成了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 != '*')