《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和指针》
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值