- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
c语言位运算详解.ppt
* §1 位运算符与位运算 位是指二进制数的一位,其值为0或1。位段以位为单位定义结构体(或共用体)中成员所占存储空间的长度。含有位段的结构体类型称为位段结构。 1. 位运算符 位运算符主要有如表11.1所示。 右移 >> 按位异或 ∧ 左移 << 按位或 | 取反 ~ 按位与 含义 运算符 含义 运算符 说明: (1)运算量只能是整型或字符型的数据。 (2)运算符中除位反(~)外,均为二目运算符,即要求两侧各有一个运算量。 2. 位运算 (1)(按位“与”) 运算规则为: 00=0,01=0,10=0,11=l (即只有当两者都为真时才为真) 例如,-59的值为1,运算过程如下: () 9 =00001001 -5 = 111l 1011 例如,-53的值为3,此时要把-5写成补码的形式,其补码为111l1011,运算过程如下: () 3 =00000011 -5 = 111l 1011 (2)|(按位“或”) 运算规则为: 0|0=0,0|l=l,1|0=l,l|l=l (即只要有一个为真其结果为真) 例如,5|9的值为13,运算过程如下: ( | ) 9 = 5 = (3) ∧(按位“异或”) 运算规则为: 0∧0=0,0∧1=1,1∧0=1,l∧1=0 (即当两者取值相异时为真) 例如,-5∧3的值为-8,运算过程如下: (∧) 3 = -5 = 111l 1011 (4)~(按位“取反”) 运算规则为: ~0=l,~l=0 (取相反的值) 例如,~7的值为-8,运算过程如下: (~) 7 =11111000 (5)<<(“左移”) 用来将一个数的各二进位全部左移若干位,右边空缺位补0。 例如,将3左移2位,结果为12。如图11.1: 0 0 0 0 0 0 1 1 0 0 0 0 1 1 0 0 左移2位 图11.1 3左移两位得到12 左移1位相当于该数乘以2,左移n位相当于该数乘以2 n。 因此,将3左移2位,相当于3乘以4。 (6)>>(“右移”) 用来将一个数的各二进位全部右移若干位。移去右端的位被舍弃,若为无符号数,左端补0。例如,将15右移3位,结果为1。如图11.2 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 1 右移3位 图11.2 15右移3位得到1 右移1位相当于该数除以2,右移n位相当于该数除以2 n ,因此,将15右移3位,相当于15/2 3 = 1(C语言规定整数相除商为整数)。 右移时应注意符号问题。对于无符号数,右移时左端补0。对于有符号数,若符号位为0(该数为正),则右移时左端补0,同无符号数的处理。若符号位为1(该数为负),则右移时左端是补0还是补1,取决于所用的计算机系统。有的系统左端补0,称逻辑右移;左端补1,称算术右移。显然,两种方式所得的结果是不一样的。Turbo C采用的是算术右移。 例如: a: 1111111111101111(补码,其十进制数是-17) a>>3 0001111111111101(逻辑右移,高位补0) a>>3 1111111111111101(算术右移,其十进制数是-3) §2 程序举例 例:取一个无符号数的4 ~ 7位。设无符号数用2个1)字节存储。 解题思路: (右移4位,使要取出的位移到最右端。如图11. 3所示 15 7 4 0 3 0 15 (2)根据提取指定位的方法,和0000000000001111(十六进制数0x000F)进行位与运算,程序如下: 图11. 3 两个字节的无符号数右移4位 # include stdio. h main( ) { unsigned a , b ; scanf (”%u” , a ) ; b=a 4 ; b=b 0x000F; printf (” \na=%u b=%u ”, a , b ) ; } 运行情况如下: 115 a=115,b=7 例 2 循环移位。要求将一个无符号数进行左循环移位。如图11. 4所示。将a左移1位,并将移出位补到右端,输入′e ′结束。 图11. 4 无符号数左循环移位 说明:此题很有实用意义。公共场合(如车站)发布信息的显示屏上滚动显示的信息,就是通过对显示缓冲区做类似处理来实现的。 解题步骤: (1)提取最高位。 (2)根据最高位为0还是1,设置标志变量为0或非0。 (3)根据标志变量的值,给最低位置0(
文档评论(0)