C语言位操作的神应用(位操作)

本文深入探讨C语言中的位操作技巧,通过四个实例详细解释了如何获取、设置、反转和旋转位。这些位操作在解决编程问题时展现出强大的功能,帮助理解语言底层原理。
摘要由CSDN通过智能技术生成

不少代码通过位操作,解题很巧妙,学习语言,就要学其精髓,学其底层,不可蜻蜓点水

例一:

函数getbits(x,p,n),返回x中从右边数第p位开始向右数n位的字段

unsigned getbits(unsigned x,int p,int n)

{

    return   (x>>(p-n)) & ~(~0<<n) ;

}

 (x>>(p-n))把期望获得的字段移到字的最右端;~(~0<<n)建立了最右边n位全为1(其他位均为0)的屏蔽码

例二:

函数setbits(x,p,n,y),返回对x执行以下操作后的结果值:将x中从第p位开始的n个(二进制)位设置为y中最右边n位的值,x的其余各位保持不变

unsigned setbits(unsigned x,int p,int n,unsigned y)

{

    return     x & ~(~(~0<<n) << (p-n) )       |        ( y & ~(~0<<n)  )  <<  (p-n) ;

}

分析:

设原为:

x: xxx...xnnnx...xxx

y: yyy.............ynnn

若想题意效果,可以:

x变为:xxx...x000x...xxx

y变为:000...0nnn0...000

再x和y做位或

x变为需要,可以:

x

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值