二进制转化、<<、>>、>>>移位运算
参考资料:
https://www.cnblogs.com/wxb20/p/6033458.html
https://www.cnblogs.com/joahyau/p/6420619.html
https://www.cnblogs.com/yulinfeng/p/6602902.html
https://www.cnblogs.com/hongten/p/hongten_java_yiweiyunsuangfu.html
https://www.cnblogs.com/xkfz007/articles/2590472.html(带小数)
一、十进制转化二进制
1、正数转化:
正数25:
| 25/2 | 12 | 1 |
| 12/2 | 6 | 0 |
| 6/2 | 3 | 0 |
| 3/2 | 1 | 1 |
| 1/2 | 0 | 1 |
最后一列,倒序排列即为二进制值。
则:25的二进制为:11001 然后32位,高位补0,即:
0000 0000 0000 0000 0000 0000 0001 1001
2、负数转化:
负数-25
1、先算出正数的二进制。
2、求反码,即二进制中1变0,0变1
3、反码+1
所以-25
1、对应的正数25对应的二进制为:
0000 0000 0000 0000 0000 0000 0001 1001
2、反码:
1111 1111 1111 1111 1111 1111 1110 0110
3、反码+1:(补码)(如果最后一位本身为1,则进位,列如1011 +1 为1100)。
1111 1111 1111 1111 1111 111 1110 0111
即为-25的二进制表示值。
二、二进制转化十进制
1、正数转化(不够32位高位补0)
011 1001
654 3210
则为:0*2^6+1*2^5+1*2^4+1*2^3+0*2^2+0*2^1+1*2^0=0+32+16+8+0+0+1=57
2、负数转化(最高位为1则为负数)
1、先算反码,即二进制中1变0,0变1
2、反码+1(补码)
3、算出对应的正数在加上负号。
例:
1111 1111 1111 1111 1111 1111 1010 1111
反码:
0000 0000 0000 0000 0000 0000 0101 0000
反码+1(如果最后一位本身为1,则进位,列如1011 +1 为1100)。
0000 0000 0000 0000 0000 0000 0101 0001
算正数:
1*2^6+0*2^5+1*2^4+0*2^3+0*2^2+0*2^1+1*2^0=64+0+16+0+0+0+1=81
即十进制为-81.
3、八进制、十六进制、十进制、二进制
01111111111111111111111111111001
十进制负数转八进制、十六进制
负数转换成八进制、十六进制,只需在补码(二进制)的基础上,3位合成一位计算,或者4位合成一位计算
-3的转换成二进制为:
1111 1111 1111 1111 1111 1111 1111 1101
八进制则将-3的二进制从右至左每3位为一个单元,不够三位用0补 即:
011 111 111 111 111 111 111 111 111 111 101
计算每一个单元,结果为:37777777775
十六进制则将-3的二进制从右至左每4位合并为一个单元,即:
1111 1111 1111 1111 1111 1111 1111 1101
计算后为: FFFFFFFD
转换十进制-3为八进制和十六进制
十六进制(0,1,2,3,4,5,6,7,8,9,A,B,C,D,F)
三:>>,<<,>>>移位运算
1、<<
<<,有符号左移位,将运算数的二进制整体左移指定位数,低位用0补齐。
正数:5<<2
1、转化为二进制:
0000 0000 0000 0000 0000 0000 0000 0
2、整体左移指2位数
0000 0000 0000 0000 0000 0000 0001 0100
3、转化为十进制
1*2^4+1*2^2=16+4=20
M<<N相当于M*2^n.
负数:-5<<2
1、转化为二进制:
1111 1111 1111 1111 1111 1111 1111
2、整体左移指2位数
1111 1111 1111 1111 1111 1111 1110 1100
3、转化为十进制
-20
M<<N相当于M*2^n.
2、>>
>>有符号右移位,将运算数的二进制整体右移指定位数,正数高位用0补齐,负数高位用1补齐(保持负数符号不变)
正数:5>>2
1、转化为二进制:
0000 0000 0000 0000 0000 0000 0000 0101
2、整体右移指2位数
0000 0000 0000 0000 0000 0000 0000 0001
3、转化为十进制
1*2^0=1
M>>N相当于M/2^n 取商
负数:-5>>2
1、转化为二进制:
1111 1111 1111 1111 1111 1111 1111 1011
2、整体右移指2位数
1111 1111 1111 1111 1111 1111 1111 1110
3、转化为十进制
-2
M<<N相当于如果运算数是偶数,那么那么它的运算结果就是 x = -(|x| / 2),如果运算数是奇数,那么它的运算结果就是 x = -(|x| / 2) - 1
3、>>>
>>>无符号右移位,不管正数还是负数,高位都用0补齐(忽略符号位)
1、正数的>>>无符号右移位和>>有符号右移位计算结果相同
2、负数
-5>>>2
1、转化为二进制:
1111 1111 1111 1111 1111 1111 1111 1011
2、整体右移指2位数
0011 1111 1111 1111 1111 1111 1111 1110
3、转化为十进制
1073741822
二进制转化、<<、>>、>>>移位运算的更多相关文章
- JAVA:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题(5)
一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...
- Java学习第五篇:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题
一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...
- java 移位运算
移位运算 :将整数转化为二进制(以补码的形式),按位平移. << 左移 >> 右移 >>> 无符号右移 << 右移: 按位做平 ...
- 【原创】Java移位运算
学习移位运算,首先得知道参与移位运算的类型的位数,那先来复习下Java基础类型的占位数吧. Java基础类型 Java基础类型总结一览表 类型 二进制位数 最大值 最小值 初始化值 表示形式 带符号 ...
- Java中的位运算符、移位运算
一.位运算 Java中有4个位运算,它们的运算规则如下: (1)按位与 (&) :两位全为1,结果为1,否则为0: (2)按位或 (|) :两位有一个为1,结果为1,否则为0: (3) ...
- C语言移位运算
移位运算有两种:>>(右移),<<(左移). a>>b表示将a的二进制值右移b位. a<<b 表示将a的二进制值左移 b位.要求 a和 b都是整型, b ...
- MATLAB的两种移位运算
MATLAB的两种移位运算: 1)circshift矩阵移位 circshift:循环移位数组 语法:B = circshift(A,shiftize) 说明: B = circshift(A,sh ...
- C++ 移位运算与进制转换 浅析
移位运算包括"逻辑移位"(logical shift)和"算术移位"(arithmetic shift). 逻辑移位:移出去的位丢弃,空缺位(vacant bi ...
- Java学习日记基础篇(八) —— 二进制、位运算、位移运算
二进制 二进制是逢2进位的进位置,0,1是基本算符 原码反码补码 在基本数据类型那里,有详细解释 二进制的最高位数是符号位:0表示整数,1表示负数 正数的原码,反码,补码都一样 负数的反码 = 它的原 ...
随机推荐
- TCP实现一个简易的聊天室 (Unity&&C#完成)
效果展示 TCP Transmission Control Protocol 传输控制协议 TCP是面向连接的流模式(俗称:网络流).即传输数据之前源端和终端建立可靠的连接,保证数据传输的正确性. 流 ...
- VisualStudio神级插件——JetBrains Resharper 2018.2.3 Ultimate完美破解版+教程
ReSharper是一个JetBrains公司出品的著名的代码生成工具,是Visual Studio里面的一个插件.它包括一系列丰富的能大大增加C#和Visual Basic .NET开发者生产力的特 ...
- MPLS 网络中的 MTU
MPLS MTU的大小可以设置为64-65535之间,在MPLS网络中,标签的大小是计入到MTU中的,所以在MPLS网络MTU是一个常见的问题. 在Ethernet接口上,一般数据最长为150 ...
- nginx 场景业务汇总 (中)
本文链接:http://www.cnblogs.com/zhenghongxin/p/8906225.html,如果可以,请阅读上篇 <nginx场景业务汇总(初)> (十三)负载均衡 轮 ...
- 1007. Minimum Domino Rotations For Equal Row
In a row of dominoes, A[i] and B[i] represent the top and bottom halves of the i-th domino. (A domi ...
- 《Python黑帽子:黑客与渗透测试编程之道》 Web攻击
Web的套接字函数库:urllib2 一开始以urllib2.py命名脚本,在Sublime Text中运行会出错,纠错后发现是重名了,改过来就好: #!/usr/bin/python #coding ...
- jzoj5923
我們可以記f[i]表示i個點的連通圖的個數 則我們可以考慮將i個點不必聯通的圖個數(記為g)減去i個點的不連通圖個數 那麼f[i]=g[i]-c(j-1,i-1)f[j]gi-j 枚舉一個j,強制將j ...
- PHP 单点登录实现方案
单点登录SSO(Single Sign On)说得简单点就是在一个多系统共存的环境下,用户在一处登录后,就不用在其他系统中登录,也就是用户的一次登录能得到其他所有系统的信任.单点登录在大型网站里使用得 ...
- python打造渗透工具集
python是门简单易学的语言,强大的第三方库让我们在编程中事半功倍,今天我们就来谈谈python在渗透测试中的应用,让我们自己动手打造自己的渗透工具集. 难易程度:★★★阅读点:python;web ...
- Kafka副本同步机制
引用自:http://blog.csdn.net/lizhitao/article/details/51718185 Kafka副本 Kafka中主题的每个Partition有一个预写式日志文件,每个 ...