(c语言)左右位移运算符小陷阱

本文通过一个具体的C语言程序示例,详细解析了位运算中的左移和右移操作,强调了位移运算并不改变原始变量值的特点,并讨论了有符号数和无符号数在位运算中的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先看一个简单的例子:
main()
{
int x = 5; // 0000 0101
printf("%d %d %d",x,x<<2,x>>2);
}

我第一遍做的答案是:5,20,5
但是正确的答案却是:2,20,1

应该注意的是,位移运算并不是对原有的数据进行位移,也就是说,x 位移之后,x的值并没有改变,除非x = x << 2。

所以上面例子中,x << 2输出了20 是没错,但是并没有改变x = 5的事实,第三个输出x >> 2,是对x = 5进行右移,答案是1。

emmm…我也不知道这到底算不算陷阱,可能只是我太粗心了。

左移右移操作还涉及有符号数和无符号数的问题,这里不再赘述。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值