在下面的语句中,认为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 ) ...
这样就不会出现赋值截短的问题了。文章来源:https://www.toymoban.com/news/detail-694163.html
参考文章来源地址https://www.toymoban.com/news/detail-694163.html
- 《C和指针》
到了这里,关于《C和指针》笔记16:赋值容易出现的误区: 赋值截短的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!