- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第12章 位运算 本章要求 位运算的概念。 数值的原码、反码和补码。 位运算符。 第12章 位运算 12.1 概述 12.2 位运算符 12.3 位运算举例 12.4 位段 12.1 概述 c语言具有高级语言的特点,又具有低级语言的功能,用途广泛。 位运算:就是对存储单元中的二进制位进行左、右移位,按位与、或、异或、取反等操作。 一、字节和位 字节(byte) 字节:内存中每一字节有一个地址,由8位二进制位组成,最右边为最低位,最左边为最高位。 字(word):由若干存储单元组成,一个单元存放一个数据或指令。 字节和位 字节(byte) 二、原码 最高位为符号位,0为正,1为负,其余各位代表数本身的绝对值。 例: +7 0 0000111 -7 1 0000111 三、反码 正数:符号位为0,数值部分不变 负数:符号位为1,数值部分取反。 例:+7 0 0000111 -7 1 1111000 12.2 位运算符 位运算量只能是整型和字符型数据 一、按位与 特点:两对应位都为1时结果为1,否则为0 例: 3的补码: 5的补码: 二 、按位或| 特点:两对应位中只有一个为1,结果便为1,否则为0 例: 3的补码: 5的补码: | 三、异或 ^ 特点:两对应位相同,结果便为0,否则为1 例: 3的补码: 5的补码: ^ 四 、取反 ~ 特点:是单目运算符,当某位原为0 时,经反运算后为1,某位原为1时,反运算后为0; 例: 3的补码: ~ 五、左移 特点:将数的二进制位全部载移若干位 例:a=a2 将a的值左移两位 若:a15 (10) 左移两位60 (10) 由此看出,左移一位相当剩余乘2,左移2位相当乘4 六、右移 特点:将数的二进制位全部右移若干位 例: b=b 2 将b的值右移两位 若b56(10) 右移两位14(16) 由此可见,右移一位除2,右移2位相当除4 最高位移入0称逻辑右移,最高位移入1称算术右移。 七、位运算符与赋值运算符结合可组成扩展赋值运算符 = |= = = ^= 如:a=b (即a=ab) a=2(即a=a2) 八、不同长度的数据进行位运算 如:long a; int b; 当进行: a b 运算时,系统自动将二者按右端对齐,变量b的左16位补0,若b为负数,左端补16位1,如果b为无符号的数,则左边也补16位0. 12.3 位运算举例 例12.0: main() { int a=13,b=12,c,d,e,f,g,h; c=ab; d=a|b; e=a^b; f=~a; g=a2; b2; Printf(“a=%d, b=%d, c=%d, e=%e, f=%d,g=%d\n”,a,b,c,d,e,f,g,h); } 例12.1:取一整数a从右端开始的4 – 7位 main( ) { unsigned a,b,c,d; scanf(“%x”,a); b=a4; c=~(~0 4); d=b c; printf(“a[8]=%o\n d[8]=%o\nc[16]=%x\n d[10]=%d\n”,a,d,c,d); } 例12.3:将变量a进行右循环移位 步骤: ①a左移16~n位(即右边
文档评论(0)