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