第12章位运算课件.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第12章位运算课件

第12章 位运算;所谓位运算是指进行二进制位的运算。在系统软件中,常要处理二进位的问题。例如,将一个存储单元中的各二进位左移或右移一位,两个数按位相加等。 12.1.1 “按位与”运算符() 参加运算的两个数据,按二进位进行“与”运算。如果两个相应的二进位都为1,则该位的结果值为1,否则为0。即00=0;01=0;10=0;11=1; 例如: 35 并不等于8,应该是按位与。 3 = 5 = ();12.1.2 按位或运算符(|) 两个相应的二进位中只要有一个为1,该位的结果值为1。即0|0=0; 0|1=1; 1|0=1; 1|1=1。例如:060|017 将八进制数60与八进制数17进行按位或运算。 (|) 12.1.3 “异或”运算符(∧) 异或运算符∧也称XOR运算符。 “异或”的意思是判断两个相应的位值是否为“异”,为“异”(值不同)就取真(1),否则为假(0)。即0∧0=0; 0∧1=1; 1∧0=1; 1∧1=0;如: (十进制数57,八进制数071) (∧ (十进制数42,八进制数052) (十进制数19,八进制数023) 即071∧052,结果为023(八进制数)。;交换两个值,不用临时变量 假如a=3,b=4。想将a和b的值互换,可以用以下赋值语句实现: a=a∧b;b=b∧a;a=a∧b; 可以用下面的竖式来说明: a=011 (∧) b=100 a=111(a∧b的结果,a已变成7) (∧)b= 100 b=011(b∧a的结果,b已变成3) (∧)a=111 a=100(a∧b的结果,a变成4);12.1.4 “取反”运算符(~) ~是一个单目(元)运算符,用来对一个二进制数按位取反,即将0变1,1变0。例如~025是对八进制数25(即二进制按位求反。 ~运算符的优先级别比算术运算符、关系运算符、逻辑运算符和其他位运算符都高,例如:~ab,先进行~a运算,然后进行运算。 ;12.1.5 左移运算符(<<) 用来将一个数的各二进位全部左移若干位。例如: a=a<<2 将a的二进制数左移2位,右补0。若a=15,即二进制左移2位即十进制数60。 高位左移后溢出,舍弃不起作用。 左移1位相当于该数乘以2,左???2位相当于该数乘以4。上面举的例子15<<2=60,即乘了4。; 12.1.6  右移运算符() a2表示将a的各二进位右移2位。移到右端的低位被舍弃,对无符号数,高位补0。如a=017时: 11a为a2为11 此二位舍弃;移入0的称为“逻辑右移”,即简单右移。移入1的称为“算术右移”。 Turbo C和其他一些C编译采用的是算术位移,例如,a的值为八进制数113755。 a:1001011111101101 a1: 0100101111110110(逻辑右移时) a1: 1100101111110110(算术右移时);12.1.7 位运算赋值运算符 位运算符与赋值运算符可以组成复合赋值运算符如:=, |=, =, =, ∧= 例如,a = b相当于 a = a b。a =2相当于:a = a 2。 12.1.8 不同长度的数据进行位运算 如果两个数据长度不同(例如long型和int型)进行位运算时(如a b,而a为long型,b为int型),系统会将二者按右端对齐。如果b为正数,则左侧16位补满0。若b为负数,左端应补满1。如果b为无符号整数型,则左侧添满0。;12.2 位运算举例 例 12.1取一个整数a从右端开始的4~7位。 例12.2循环移位。要求将a进行右循环移位。见图12.4。图12.4表示将a右循环移n位。即将a中原来左面(16-n)位右移n位,原来右端n位移到最左面n位。今假设用两个字节存放一个整数。;12.3位段 怎样向一个字节中的一个或几个二进位赋值和改变它的值呢?可以用以下两种方法: (1) 可以人为地在一个字节data中设几项。例如:a、b、c、d分别占2位、6位、4位、4位(见图12.5)。如果想将c的值变为12(设c原来为0),可以这样:;  ; 11 11111 1 0000

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档