《C和指针》笔记16:赋值容易出现的误区: 赋值截短

在下面的语句中,认为a和x被赋予相同的值的说法是不正确的:

a = x = y + 3;

它等价于

a = (x = y + 3);

如果x是一个字符型变量,那么y+3的值就会被截去一段,以便容纳于字符类型的变量中。那么a所赋的值就是这个被截短后的值。在下面这个常见的错误中,这种截短正是问题的根源所在:

char ch;
...
while( ( ch = getchar() ) != EOF ) ...

EOF需要的位数比字符型值所能提供的位数要多,这也是getchar返回一个整型值而不是字符值的原因。然而,把getchar的返回值首先存储于ch中将导致它被截短。然后这个被截短的值被提升为整型并与EOF进行比较。当这段存在错误的代码在使用有符号字符集的机器上运行时,如果读取了一个值为\377(8进制)的字节时,循环将会终止,因为这个值截短再提升之后与EOF相等。当这段代码在使用无符号字符集的机器上运行时,这个循环将永远不会终止!

我们应该写成

int ch;
...
while( ( ch = getchar() ) != EOF ) ...

这样就不会出现赋值截短的问题了。

参考

  1. 《C和指针》

你可能感兴趣的:(C和C++,c语言,笔记,开发语言,赋值截短,误区)