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

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

不过要掌握一个思路

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

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

计算机不会做加法(位运算)_第1张图片

 

 

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

计算机不会做加法(位运算)_第2张图片

 

 

 三.位运算

1.与运算

计算机不会做加法(位运算)_第3张图片

 

 

 

2.或运算

计算机不会做加法(位运算)_第4张图片

 

 

 

3.异或运算

计算机不会做加法(位运算)_第5张图片

 

 

 

4.非运算(取反)

计算机不会做加法(位运算)_第6张图片

 

5.左移动(相对简单)

 

 计算机不会做加法(位运算)_第7张图片

 

 

6.右移

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

                  右移动 补符号位就用sar

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

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

unsigned无符号

int计算机就是默认有符号

计算机不会做加法(位运算)_第8张图片

 

 

 

 

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

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

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

计算机不会做加法(位运算)_第9张图片

 

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

计算机不会做加法(位运算)_第10张图片

 

 

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

 

 

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

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

 

 计算机不会做加法(位运算)_第11张图片

 

 计算机不会做加法(位运算)_第12张图片

 

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

整体过程

计算机不会做加法(位运算)_第13张图片

 

 

2.

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

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

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

 

计算机不会做加法(位运算)_第14张图片

 

 

 

   计算机不会做加法(位运算)_第15张图片

 

 

 计算机不会做加法(位运算)_第16张图片

 

你可能感兴趣的:(计算机不会做加法(位运算))