main() { int c; while ((c = getchar()) != EOF) putchar(c); }
Verify that getchar() != EOF IS 0 OR 1
我想我明白发生了什么:
> c从键盘分配下一个字符
c检查是否为EOF
> c被分配1或0,取决于它是否是EOF.
>字符显示在输出上,或者如果EOF结束程序.
main () { int c; while ((c = getchar()) != EOF) printf("%d\n",c); }
这只是打印字符的值.如果我按回车键,也打印“10”.
我以为会打印c.但是,它正在打印字符的值而不是1或0的值.
我知道c与EOF进行比较后分配1或0.但我不知道可以用什么逻辑来显示这个.似乎我需要以某种方式“显示”显示字符值,而是显示比较值.这是否意味着我需要摆脱while循环?如果是这样,我不知道如何(这只是一个猜测).
我怎样才能验证c = 1或0?
而且,我该怎么知道这个?我想,我应该从中学到一些根本的东西.
main () { int c; while ((c = getchar()) != EOF != 0 != 1) putchar(c); }
解决方法
I know c is assigned 1 or 0 after comparing it with EOF
不,不行看:
while ((c = getchar()) != EOF)
表达式是:(c = getchar())!= EOF,其中包含另一个表达式:(c = getchar()),它从键盘分配给c的字符. c不会等于0或1!这是表达的结果.尝试这段代码:
int main() { char value; int c; value = ((c = getchar()) != EOF); printf("%i\n",value); return 0; }
该代码将打印表达式的值(c = getchar())!= EOF.其实你的代码可以这样写:
int main () { int c; char value = ((c = getchar()) != EOF); while (value) { printf("%d\n",c); value = ((c = getchar()) != EOF); } return 0; }
该表达式不再在同一时间,其结果被赋值给值.上面的代码和你的代码将会产生完全相同的输出.
编辑:
`main () { int c; while ((c = getchar()) != EOF != 0 != 1) putchar(c); }`
`main () { int c; char value1; char value2; char value3; value1 = ((c = getchar()) != EOF); value2 = value1 != 0; value3 = value2 != 1; while (value3) { putchar(c); value1 = ((c = getchar()) != EOF); value2 = value1 != 0; value3 = value2 != 1; } }`
那么会发生什么?
假设getchar会返回字符“A”.所以value1将等于1,因为’A’不同于EOF. value2将等于1,因为value1(等于1)不等于0. value3将等于0,因为value2(等于1)不等于1:while(value3)现在是(0),所以不会打印任何字符.
重要的是要理解,您可以将变量分配给比较表达式的结果(这意味着至少有一个比较运算符的表达式),并且此类表达式的结果为0(对于false)或1(为true) .
关于OP的评论的话很少
Hey,thanks. But K&R explicitly says “This has the undesired effect of setting c to 1 or 0”. Maybe this is why I’m confused.
如果while看起来像这样,c将被分配到0或1:
while (c = getchar() != EOF)
operator =具有比operator =更大的优先级.这意味着getchar()!= EOF将首先进行评估,然后将其结果分配给c.