




已阅读5页,还剩16页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第12章位运算,12.1位运算符和位运算12.2位运算举例12.3位段,1,12.1位运算符和位运算,2,数值在计算机中的表示,1.二进制位与字节计算机系统的内存储器,是由许多称为字节的单元组成的,1个字节由8个二进制位(bit)构成,每位的取值为0/1。最右端的那1位称为“最低位”,编号为0;最左端的那1位称为“最高位”,而且从最低位到最高位顺序,依次编号。图11-1是1个字节各二进制位的编号。图11-11个字节各二进制位的编号2.数值的原码表示数值的原码表示是指,将最高位用作符号位(0表示正数,1表示负数),其余各位代表数值本身的绝对值(以二进制形式表示)的表示形式。为简化描述起见,本节约定用1个字节表示1个整数。,3,例如,+9的原码是00001001符号位上的0表示正数-9的原码是10001001。符号位上的1表示负数3.数值的反码表示数值的反码表示分两种情况:(1)正数的反码:与原码相同。例如,+9的反码是00001001。(2)负数的反码:符号位为1,其余各位为该数绝对值的原码按位取反(1变0、0变1)。例如,-9的反码:因为是负数,则符号位为“1”;其余7位为-9的绝对值+9的原码0001001按位取反为1110110,所以-9的反码是11110110。,4,4.数值的补码表示数值的补码表示也分两种情况:(1)正数的补码:与原码相同。例如,+9的补码是00001001。(2)负数的补码:符号位为1,其余位为该数绝对值的原码按位取反;然后整个数加1。例如,-9的补码:因为是负数,则符号位为“1”;其余7位为-9的绝对值+9的原码0001001按位取反为1110110;再加1,所以-9的补码是11110111。已知一个数的补码,求原码的操作分两种情况:(1)如果补码的符号位为“0”,表示是一个正数,所以补码就是该数的原码。(2)如果补码的符号位为“1”,表示是一个负数,求原码的操作可以是:符号位不变,其余各位取反,然后再整个数加1。,5,例如,已知一个补码为11111001,则原码是10000111(-7):因为符号位为“1”,表示是一个负数,所以该位不变,仍为“1”;其余7位1111001取反后为0000110;再加1,所以是10000111。5.数值在计算机中的表示补码在计算机系统中,数值一律用补码表示(存储),原因在于:使用补码,可以将符号位和其它位统一处理;同时,减法也可按加法来处理。另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。,6,12.1.1按位与运算符printf(Inputaintegernumber:);scanf(%d,13,程序说明:(04)按位取0的反,为全1;左移4位后,其低4位为0,其余各位为1;再按位取反,则其低4位为1,其余各位为0。这个整数正是我们所需要的。例从键盘上输入1个正整数给int变量num,按二进制位输出该数,14,#includestdio.hmain()intnum,mask,i;printf(Inputaintegernumber:);scanf(%d,15,12.3位段,有时,存储1个信息不必占用1个字节,只需二进制的1个(或多个)位就够用。如果仍然使用结构类型,则造成内存空间的浪费。为此,C语言引入了位段类型。,16,1.位段的概念与定义所谓位段类型,是一种特殊的结构类型,其所有成员均以二进制位为单位定义长度,并称成员为位段。例如,CPU的状态寄存器,按位段类型定义如下:structstatusunsignedsign:1;/*符号标志*/unsignedzero:1;/*零标志*/unsignedcarry:1;/*进位标志*/unsignedparity:1;/*奇偶/溢出标志*/unsignedhalf_carry:1;/*半进位标志*/unsignednegative:1;/*减标志*/flags;,17,显然,对CPU的状态寄存器而言,使用位段类型(仅需1个字节),比使用结构类型(需要6个字节)节省了5个字节。2.说明(1)因为位段类型是一种结构类型,所以位段类型和位段变量的定义,以及对位段(即位段类型中的成员)的引用,均与结构类型和结构变量一样。(2)对位段赋值时,要注意取置范围。一般地说,长度为n的位段,其取值范围是:0(2n-1)。(3)使用长度为0的无名位段,可使其后续位段从下1个字节开始存储。,18,例如,structstatusunsignedsign:1;/*符号标志*/unsignedzero:1;/*零标志*/unsignedcarry:1;/*进位标志*/unsigned:0;/*长度为0的无名位段*/unsignedparity:1;/*奇偶/溢出标志*/unsignedhalf_carry:1;/*半进位标志*/unsignednegative:1;/*减标志*/flags;,19,原本6个标志位是连续存储在1个字节中的。由于加入了1个长度为0的无名位段,所以其后的3个位段,从下1个字节开始存储,一共占用2个字节。(4)1个位段必须存储在1个存储单元(通常为1字节)中,
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年教师招聘之《小学教师招聘》考前冲刺测试卷包附答案详解【巩固】
- 教师招聘之《小学教师招聘》考前冲刺训练试卷含完整答案详解(考点梳理)
- 优.质工程临电方案(3篇)
- 2025年教师招聘之《幼儿教师招聘》练习题库包附参考答案详解(b卷)
- 2025年学历类自考国际企业管理-学前教育科学研究参考题库含答案解析(5卷)
- 教师招聘之《幼儿教师招聘》练习题附参考答案详解【典型题】
- 教师招聘之《幼儿教师招聘》高分题库含答案详解【综合卷】
- 宁波象山县事业单位招聘考试真题2024
- 2024年贵阳市云岩区教师招聘真题
- 2025内蒙古呼伦贝尔陆港国际有限公司市场化选聘总经理、副总经理笔试备考及完整答案详解
- 抢救工作制度培训课件
- 无人机航空摄影测量数据获取与处理PPT完整全套教学课件
- 肺部感染性疾病-课件
- 电气试验(第二版)11-057职业技能鉴定指导书职业标准试题库(仅高级工)
- 把未来点亮歌词打印版
- 全国211大学名单和985高校名单(表格+文档)
- 浴场委托管理合同
- PFEP培训资料 -让物料流动起来-为每个零件制定计划和创建一个物流系统
- 《高级财务管理(第三版)》配套教学课件
- QGDW 11162-2014-变电站监控系统图形界面规范
- 平均站间距计算方法
评论
0/150
提交评论