V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
echo1937
V2EX  ›  C

问个C语言的问题,验证布尔表达式getchar() != EOF的取值是0还是1.

  •  
  •   echo1937 · 2013-06-24 01:22:06 +08:00 · 1512 次点击
    这是一个创建于 4206 天前的主题,其中的信息可能已经有所发展或是发生改变。
    源码:
    #include <stdio.h>

    int main(int argc, char const *argv[])
    {
    int c;
    while( c = getchar() != EOF )printf("%d \n", c);
    printf("%d - at EOF \n",c );
    return 0;
    }

    系统环境:Mac OS X 10.8.4

    Clang编译报错:
    $clang -v
    Apple LLVM version 4.2 (clang-425.0.28) (based on LLVM 3.2svn)
    Target: x86_64-apple-darwin12.4.0
    Thread model: posix

    $clang 1-6.c
    1-6.c:34:11: warning: using the result of an assignment as a condition without parentheses [-Wparentheses]
    while( c = getchar() != EOF )
    ~~^~~~~~~~~~~~~~~~~~
    1-6.c:34:11: note: place parentheses around the assignment to silence this warning
    while( c = getchar() != EOF )
    ^
    ( )
    1-6.c:34:11: note: use '==' to turn this assignment into an equality comparison
    while( c = getchar() != EOF )
    ^
    ==
    1 warning generated.

    Gcc编译可以通过:
    $gcc -v
    Using built-in specs.
    Target: i686-apple-darwin11
    Thread model: posix
    gcc version 4.2.1 (Based on Apple Inc. build 5658) (LLVM build 2336.11.00)

    但是结果很诡异,多出一个1来,
    $./a.out
    qaz
    1
    1
    1
    1

    clang编译不通过好理解,gcc下面为什么多出个1呢.
    9 条回复    2015-02-04 23:38:18 +08:00
    darasion
        1
    darasion  
       2013-06-24 01:33:50 +08:00   ❤️ 1
    回车也算.
    edgar
        2
    edgar  
       2013-06-24 12:08:24 +08:00
    clang那个是警告吧,而且你的gcc版本比较低,高版本的应该也会报错。
    edgar
        3
    edgar  
       2013-06-24 12:33:28 +08:00
    还有就是,那个1其实是getchar() != EOF的结果,改成(c=getchar())!=EOF应该就可以了
    dndx
        4
    dndx  
       2013-06-24 12:39:50 +08:00   ❤️ 1
    c = getchar() != EOF

    因为 != 的优先级比 = 高,上面的代码等同于:

    c = (getchar() != EOF)

    所以你的 c 变量在检测到 EOF 之前都是 0 ,估计不是你想要的效果。

    改成

    (c = getchar()) != EOF
    cmi
        5
    cmi  
       2013-08-07 00:58:07 +08:00
    这题是K&R的Exercise 1-6吧?题目本来就是要验证 getchar() != EOF 的取值是0还是1。

    多一个1是因为“回车也算.”。:)

    我不明白的地方在于:
    由于while (expression)的expression在此例里总是不为0,while循环无法结束,printf("%d - at EOF \n",c )永远无法执行,但是我想让这一句打印出来。

    依照系统,EOF被定义为(-1),

    #ifndef EOF
    # define EOF (-1)
    #endif

    我即使输入(-1),也无法让getchar() == EOF,这是什么原因?我哪里理解错了?
    cmi
        6
    cmi  
       2013-08-07 01:05:20 +08:00
    刚回复完似乎有点明白了,即使getchar() == EOF,也只不过是给 c 赋了另外一个条件,并没有让c=0,所以while永远无法结束。
    但是将一个条件赋予c,这算是什么语法?

    这么理解正确吗?
    cmi
        7
    cmi  
       2013-08-07 01:13:56 +08:00
    好像还不对。
    这么测试总是要输入回车,这导致getchar() != EOF永远为真。
    echo1937
        8
    echo1937  
    OP
       2013-08-07 08:40:59 +08:00
    @cmi 感谢你的回复,这个问题我去看了英文版,答案和中文版是不一样的.


    英文版的答案是:

    #include <stdio.h>

    int main(void)
    {
    printf("Press a key. ENTER would be nice :-)\n\n");
    printf("The expression getchar() != EOF evaluates to %d\n", getchar() != EOF);
    return 0;
    }

    看来是中文版的问题吧.
    vtvincy
        9
    vtvincy  
       2015-02-04 23:38:18 +08:00
    兩個答案都是正確的, 回車也是一個字符所以多出來一個1
    看看這篇文章會有幫助:
    http://www.ruanyifeng.com/blog/2011/11/eof.html
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2724 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 09:00 · PVG 17:00 · LAX 01:00 · JFK 04:00
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.