二进制运算-十进制与二进制的转换

Posted saltiest

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二进制运算-十进制与二进制的转换相关的知识,希望对你有一定的参考价值。

在学习JDK源码和JAVA一些开源框架源码的时候经常会碰到位运算,要搞懂位运算就得弄明白二进制和十进制之间的转换

一、十进制转换成二进制

1.正整数转换成二进制

十进制整数转换成二进制就是不停的除以二,直到不足二为止(0或者1),然后记录余数,从下往上排列出来就是二进制的值

举个例子:5和8转换成二进制

技术图片

 5的二进制为101,8的二进制为1000

2.负整数转换成二进制

负整数转换成二进制,首先取得它绝对值的正数的二进制,然后取反(0变1,1变0),然后加1

举个例子:-5的二进制(32位计算机中)

第一步:5的二进制101,高位补0之后32位计算机中就是:0000 0000 0000 0000 0000 0000 0000 0101

第二步:取反,1111 1111 1111 1111 1111 1111 1111 1010  (反码)

第三步:加一,1111 1111 1111 1111 1111 1111 1111 1011  (补码)

如果你使用的是windows系统可以拿去验证,比如我是64位系统 -5的二进制是1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1111 1011

技术图片技术图片

 3.小数转换成二进制

首先把整数部分转换成二进制,然后把小数位转换(小数为换算每次乘2,不足1为0),最后相加

举个例子:3.15的二进制 

第一步:3的二进制11

第二步:0.15的二进制0.001,如图

技术图片

第三步:相加得11.001

 

一、二进制转换成十进制

1.二进制转换成十进制整数

举个例子:

101的十进制和 1110的十进制

技术图片                 技术图片

 

2.二进制转换成十进制负数

-5的二进制是111 1111 1111 1111 1111 1111 1111 1011,反码是0000 0000 0000 0000 0000 0000 0000 0100,加一是0000 0000 0000 0000 0000 0000 0000 0101,十进制就是5,取相反数则是-5

3.二进制转换成十进制整数

举个例子:3.15的二进制是11.001

技术图片

 

以上是关于二进制运算-十进制与二进制的转换的主要内容,如果未能解决你的问题,请参考以下文章

数据结构与算法-位运算

进制转换及位运算符

进制与位运算

二进制与十进制的转换

位运算与二进制

python位运算