• 计算机不会做加法(位运算)


    之前还有一个计算机的原码反码补码,这些比较简单 ,大家可以自行了解

    不过要掌握一个思路

    拿到一个二进制数据时    拿到数据(二进制)———>  搞清楚时以什么方式编码(视频还是txt)——————>根据不用方式的编码规则编码

    一. 计算机的运算--(位运算)

     二.为什么要学习位运算??

     三.位运算

    1.与运算

    2.或运算

    3.异或运算

    4.非运算(取反)

    5.左移动(相对简单)

     

    6.右移

    在汇编里面右移动 补0就用shr

                      右移动 补符号位就用sar

    在c语言里面补0和补符号位用的都是>>

    c语言会根据unsigned和int来判断你是有符号还是无符号数,然后决定补0还是

    unsigned无符号

    int计算机就是默认有符号

    四.通过位运算实现四则运算

    1. 比如4+5的运算过程

    可以发现 在没有进位的情况下,加法和异或的结果一致

     所以当计算机运算的时候,先 异或  在判断有没有 进位  再 异或 

     

     与运算是为了判断哪个位置出现进位这个位置出现进位

    异或并没有将进位考虑过去

    所以要把进位的结果和异或的结果再相加,注意的是 我们再次加的时候要把0000 0100 左移1位(因为有一个进位)

     

     

     

     再判断是否有进位 与一下看是否为0 没进位了就是最终结果

    整体过程

    2.

    4-5(其实也就是加法)

    也就是4+(-5)负数的运算是以补码形式进行的

    先异或 完事再与一下看看有没有进位 没有就完事了

     

     

       

     

     

  • 相关阅读:
    Java中的多线程你只要看这一篇就够了
    模板CodeTemplate
    mybatis_mysql
    Kettle 使用Json输入
    图解ByteBuffer
    双队列缓存
    log4j.properties配置详解与实例
    Kettle 使用Json输入
    JSON响应端模拟测试
    使用Kettle导出excel
  • 原文地址:https://www.cnblogs.com/cat47/p/12238430.html
Copyright © 2020-2023  润新知