目录:
    一、机器数和真值
    二、原码,反码和补码的基础概念
    三、为什么要使用原码,反码和补码
    四、原码,补码,反码再深入
    五、数据溢出测试
    、位运算的运算说明
    七、位运算的简单应用 
 

一、机器数和真值
 
    机器数(computer number)是数字在计算机中的二进制表示形式
    机器数有2个特点:一是符号数字化,二是其数的大小受机器字长的限制
    比如:十进制中的+6,计算机字长为8位,转换成二进制就是00000110,如果是-6,就是10000110
    这里的00000110和10000110便是机器数
 
    因为第一位是符号位(正数该位为0,负数该位为1,0分+0和-0),所以:
        ①8位二进制数的取值范围就是:[1111 1111 , 0111 1111]
        ②机器数的形式值就不等于真正的数值。
            为区别起见,将带符号位的机器数对应的真正数值称为机器数的真值。
            比如:0000 0001的真值 = +000 0001 = +1,1000 0001的真值 = –000 0001 = –1
 
 
二、原码,反码和补码的基础概念
 
    对于一个数, 计算机要使用一定的编码方式进行存储。原码, 反码, 补码是机器存储一个具体数字的编码方式
        [+1] = [00000001]原 = [00000001]反 = [00000001]补
        [-1] = [10000001]原 = [11111110]反 = [11111111]补
 
    1.原码
        原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值
    2.反码
        正数的反码是其本身
        负数的反码是在其原码的基础上, 符号位不变,其余各个位取反
    3.补码        
        正数的补码就是其本身
        负数的补码即是在反码的基础上+1
        由此可见,正数的原码反码补码都是自身,负数的反码,补码都无法直观看出其数值,需要转换成原码再计算其数值
 
 
三、为什么要使用原码,反码和补码
 
    对于计算机,加减乘数已经是最基础的运算, 要设计的尽量简单,而让计算机辨别"符号位"显然会让计算机的基础电路设计变得十分复杂。于是人们开始探索将符号伪参与运算,并且只保留加法的方法
 
    若用原码计算十进制减法:1-1=0,结果是不正确的:
        1 - 1 = 1 + (-1) = [00000001]原 + [10000001]原 = [10000010]原 = -2
    使用反码时,结果的真值部分正确:
        1 - 1 = 1 + (-1) = [0000 0001]原 + [1000 0001]原= [0000 0001]反 + [1111 1110]反 = [1111 1111]反 = [1000 0000]原 = -0
    而反码的问题在于0上,反码中会有[0000 0000]原=+0和[1000 0000]原=-0两个编码表示0,于是出现了解决这一问题的补码[1000 0000]补(8位二进制机器数中,补码还能够多表示一个最低数-128=[1000 0000]补):
        1-1 = 1 + (-1) = [0000 0001]原 + [1000 0001]原 = [0000 0001]补 + [1111 1111]补 = [0000 0000]补=[0000 0000]原
 
 
四、原码,补码,反码再深入
 
    x mod y等于 x 减去 y 乘上 x与y的商的下界
    一个数的反码, 实际上是这个数对于一个模的同余数,而这个膜并不是我们的二进制, 而是所能表示的最大值
    由于0的特殊情况, 没有办法表示128, 所以补码的取值范围是[-128, 127]
 
 
五、数据溢出测试
    待补上~~~
 
六、位运算的运算说明
 
    1. & 按位 与「AND」
        功能:对应的两个二进位 均为1 时,结果 为1,否则 为0
        例子:9&5 = 1001&0101 = 0001,即 9&5=1
        *规律:二进制中与 1& 保持原位,与  0& 为0
 
    2. | 按位 或「OR」
        功能:对应的两个二进位 只要有一个为1 时,结果 为1,否则 为0
        例子:9|5 = 1001|0101 = 1101,即 9|5=13
 
    3. ^ 按位 异或「XOR,EOR」
        功能:对应的两个二进位 不相同 为1,否则 为0
        例子:9^5 = 1001^0101 = 1100,即 9^5=12
        *规律:
            同一整数 相异或 为0,               例:5^5=0
            不同整数 相异或 结果和顺序无关,例:5^6^7 = 5^7^6
            任何数 和 0 异或 结果不变,        例:x^0 = x
            综上,x^y^x = x^x^y = 0^y = y
 
    4. ~ 按位 取反「NOR」
        功能:对整数的 每一位取反,符号也位取反「取反:0取反为1,1取反为0」
        例子:~9 = -10(因为负数是补码存储的)
            ~9=~[00001001]原=[11110110]补=[11110101]反=[10001010]原=-10
 
    5. << 左移(shl)
        格式:整数<<左移个数
        例子:x << n
        实质:x * 2n
        操作:把 x 的二进制位 向左移动 n 个单位,高位丢弃,低位补0
 
    6. >> 右移(shr)
        格式:整数>>右移个数
        例子:x >> n
        实质:x / 2n
        操作:把 x 的二进制位 向右移动 n 个单位,低位丢弃,符号位不变
        注意:符号位也跟着移动, 右移不改变整数的正负, 最后符号位要调整为原来的数值
        正数 符号位为 0, 最高位补0
        负数 符号位为 1, 最高位补1
 
 
七、位运算的简单应用
 
    1.(& 按位 与「AND」)奇偶判断
        取模判断:a%2?printf(“奇数\n”):printf(“偶数\n”);
        与壹判断:a&1?printf(“奇数\n”):printf(“偶数\n”);
 
    2.(^ 按位 异或「XOR,EOR」)数值转换
        借助第三方变量:temp = a;a = b;b = temp;
        不借助额外空间,数学法:a = b - a;b = b - a;a = b + a;
        不借助额外空间,位运算:a = a ^ b;b = a ^ b;a = a ^ b;
 
    3.(<< 左移 和 >> 右移)优化乘除法效率
        a shl b 的值等于a乘以2的b次方
        a shr b 比如二分查找、堆的插入操作等等

C语言原码反码补码与位运算.的更多相关文章

  1. 「C语言」原码反码补码与位运算

    尽管能查到各种文献,亲自归纳出自己的体系还是更能加深对该知识的理解.     本篇文章便是在结合百度百科有关原码.反码.补码和位运算的介绍并深度借鉴了张子秋和Liquor相关文章后整理而出.   目录 ...

  2. JAVA:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题(5)

    一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...

  3. Java学习第五篇:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题

    一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...

  4. java原码反码补码以及位运算

    原码, 反码, 补码的基础概念和计算方法. 对于一个数, 计算机要使用一定的编码方式进行存储. 原码, 反码, 补码是机器存储一个具体数字的编码方式. 1. 原码 原码就是符号位加上真值的绝对值, 即 ...

  5. C语言 原码--反码--补码

    //原码,反码,补码 #include<stdio.h> #include<stdlib.h> //数值的表示方法——原码.反码和补码 //原码:最高位为符号位,其余各位为数值 ...

  6. C语言基础(4)-原码,反码,补码及sizeof关键字

    1. 原码 +7的原码是0000 0111 -7的原码是1000 0111 +0的原码是0000 0000 -0的原码是1000 0000 2. 反码 一个数如果值为正,那么反码和原码相同. 一个数如 ...

  7. C语言学习笔记之原码反码补码

    原码:就是我们自己看的,以及机器输出给我们看的 补码:机器永远是以补码的形式将数据保存在计算机中 正数: 原码=反码=补码 负数: 反码:原码的符号位不变,其他位取反 ,1变0   0变1 补码:机器 ...

  8. 原码 & 反码 & 补码 & 详解

    本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...

  9. python之计算机硬件基本认知_数据单位_进制间转换_数的原码反码补码

    一:计算机硬件基本认知 cpu:   中央处理器.   相当于人的大脑.运算中心,控制中心. 内存:  临时存储数据. 优点:读取速度快,缺点:容量小,造价高,断电即消失. 硬盘:  长期存储数据. ...

随机推荐

  1. 三、singleton(单例化)一个对象的几种方法

    方案一:私有化构造器,通过static final域 @Test public void test13() { A215 a=A215.a; A215 b=A215.a; System.out.pri ...

  2. 【USACO 1.4.1】铺放矩形块

    [描述] 给定4个矩形块,找出一个最小的封闭矩形将这4个矩形块放入,但不得相互重叠.所谓最小矩形指该矩形面积最小.               所有4个矩形块的边都与封闭矩形的边相平行,图1示出了铺放 ...

  3. 8个不可不知的Mac OS X专用命令行工具(转)

    OS X的终端下通用很多Unix的工具和脚本.如果从Linux迁移到OS X会发现很多熟悉的命令和脚本工具,其实并没有任何区别. 但是OS X也提供了很多其他系统所没有的特别的命令行工具.我们推荐8个 ...

  4. CentOS6.5 下 Mysql5.7主从复制

    包下载http://url.cn/WrNg5S 主数据库:192.168.161.129 从数据库1:192.168.161.130 从数据库1:192.168.161.138 MySQL安装地址:/ ...

  5. 初涉JavaScript模式 (12) : 沙箱模式

    引子 上一篇说了模块模式,而对于其中的命名空间模式其实也是有着一些问题,比如每添加一个模块或则深入叠加都会导致长命名,并且对于多个库的不同版本同时运行,一不小心就会污染全局标识,而这两天也发现了JSe ...

  6. core文件生成总结

    1.确定系统支持生成core dump文件 ulimit -c    如果返回0, 可以ulimit -c unlimited 设定 2.kill 加上信号量, kill 信号如下 信号 信号值 功能 ...

  7. sqlserver 进行MD5加密

    官方定义函数: HashBytes ( '<algorithm>', { @input | 'input' } )  <algorithm>::= MD2 | MD4 | MD ...

  8. k-近邻算法理解

    左图中,绿色圆要被决定赋予哪个类,是红色三角形还是蓝色四方形?如果K=3,由于红色三角形所占比例为2/3,绿色圆将被赋予红色三角形那个类,如果K=5,由于蓝色四方形比例为3/5,因此绿色圆被赋予蓝色四 ...

  9. 如何改变dreamweaver的编码方式

  10. WPF利用动画实现圆形进度条

    原文:WPF利用动画实现圆形进度条 这是我的第一篇随笔,最近因为工作需要,开始学习WPF相关技术,自己想实现以下圆形进度条的效果,逛了园子发现基本都是很久以前的文章,实现方式一般都是GDI实现的,想到 ...