C案例教程教案(ord文档)第十一章.docVIP

  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文档。上传文档
查看更多
C案例教程教案(ord文档)第十一章

第11章? 位运算?第一节?????????? ? 一般用字节(Byte)作为计算机信息的基本单位,一个字节由8个二进制位组成,其中最右边的一位称为“最低有效位”LSB,最左边的一位称为“最高有效位”MSB,如图11-1所示。最低有效位也称第0位,最高有效位也称第7位。? ? 第 7 位 ? 第 6 位 ? 第 5 位 ? 第 4 位 ? 第 3 位 ? 第 2 位 ? 第 1 位 ? 第 0 位 ? 表11-1 ? 位运算符 含义 按位与 MSB ? ? ? ? ? ? LSB ? | 按位或 1 0 0 1 0 0 0 1 ? ^ 按位异或 ? 图11-1 ? ~ 按位取反 ? ? 左移 ? 右移 C语言提供了6种位运算符,如表11-1所示。 ? 说明: (1) 位运算符中除了“~” 以外,均为二目运算符。 (2) 运算量只能是整型或字符型的数据,不能为实型数据。 ? ?? 一、???????? ()? 1.运算规则? 参加运算的两个运算量,如果两个相对应的位都为1,该位结果值为1,否则为0。可记为“见0则0”。? ? 1 0 0 1 1 0 0 1 1 1 1 0 1 0 1 0 ? 1 0 0 0 1 0 0 0 2.“按位与”的特殊用途 ? (1)清零 方法:任何数与一个各个位均为零的数值相与,结果为零。 ? 1 0 0 1 1 0 0 1 0 0 0 0 0 0 0 0 ? 0 0 0 0 0 0 0 0 (2)取一个数X中某些指定位。 方法:找一个数,此数的各个位将按照这样原则取值:对应于x要取的位,该数对应位为1,其余位为0。则此数与x按位相与就可以得到X中的某些位。 例11-3 假设有X=l0101110B,想取X的低4位。 分析:由于欲取X的低4位1,则可以将X与Y相与,即可得到X的低4位。则有:? ? 1 0 1 0 1 1 1 0 0 0 0 0 1 1 1 1 ? 0 0 0 0 1 1 1 0 ?? 二、???????? 1.运算规则 参加运算的两个运算量,如果两个相对应的位中有—个为1,则该位结果值为1,否则为0。可记为“见1则1”。 ? 1 1 0 1 0 0 1 1 | 1 0 0 0 1 0 1 0 ? 1 1 0 1 1 0 1 1 2.“按位或”的特殊用途: 常用来对一个数据的某些位置1:? 就是找一个数,此数的各个位将按照这样规则取值:对应于X要置1的位,该数对应位为1,其余位为零0,则此数与X相或就可使X中的某些位置1。 例11-5 假设有X,想使X的低4位为l。 ? 1 1 0 1 0 0 1 0 | 0 0 0 0 1 1 1 1 ? 1 1 0 1 1 1 1 1 三、????????? (^) ? 1.运算规则 参加运算的两个运算量,如果两个对应的位为相“异”(值不同),则该位结果值为1。可记为“见同则0”。? ? 1 0 0 0 1 0 0 1 ^ 1 1 1 0 1 1 1 0 ? 0 1 1 0 0 1 1 1 2.“异或”的特殊用途:使特定位翻转 方法:找—个数,此数的各个位将按照这样规则取值:对应于X要翻转的位,该数对应位为1,其余位为零。则此数与X相异或即可。 例ll-7 假设有X,则想使X的低4位翻转。 ? 1 0 1 0 1 1 1 0 ^ 0 0 0 0 1 1 1 1 ? 1 0 1 0 0 0 0 1 ?四、???????? (~) ?1.运算规则 对一个二进制数按位取反,即将0变为l,1变为0。 ~ 1 0 0 0 1 0 1 1 ? 0 1 1 1 1 1 0 0 2.注意事项 (1) 单目运算符,具有右结合性; (2) ~运算符的优先级别比算术运算符、关系运算符逻辑远符和其运算符都高。? ?? 五、???????? ()? 运算规则:将一个数的各个二进制全都左移若干位(左丢弃,右补0)。 ?? 六、???????? ()? 运算规则:将一个数的各个二进制全部右移若干位。最端低位丢弃,对于无符号数最高位补0;对于有符号数:正数则最高位补0,如果为负数,左端最高位补0还是补1则取决于所用的C编译系统。如果补0则称为“逻辑右移”,补l则称为“算术右移”。 ??? 七、???????? ? 位运算符与赋值运算符相结合,就组成复合赋值运算符,表11-2所示。 表11-2 复合赋值运算符 实例 等价实例 = a=b a=ab | = a | =b a=a | b ^= a^=b a=a^b = a=b a=ab = a=b a=ab 第二节?????????? ?有时信息不需

文档评论(0)

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

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

1亿VIP精品文档

相关文档