java 移位运算
移位运算 :将整数转化为二进制(以补码的形式),按位平移。
<< 左移
>> 右移
>>> 无符号右移
<< 右移:
按位做平移,末位用0补上(正负数都一样)
a << n;
如果 a 是 byte、short、int 类型 那么 a << n 就是 a << (n%32)
int a = 5;
System.out.println(a<<3); //输出 40
System.out.println(a<<35); //输出 40
如果 a 是 long 类型 那么 a << n 就是 a << (n%64)
long a = 5;
System.out.println(a<<3); //输出 40
System.out.println(a<<35); //输出 171798691840
System.out.println(a<<67); //输出 40
注意 :由于这只是按位平移,有可能符号化会改变
int a = 1;
a<<=31;
System.out.println(a); //输出 -2147483648
System.out.println(Integer.toBinaryString(a)); //输出 1000 0000 0000 0000 0000 0000 0000 0000
由于最高位是1所以是一个负数
>> 右移:
按位做平移
如果 a 是 byte、short、int 类型 那么 a >> n 就是 a >> (n%32)
int a = 40;
System.out.println(a>>3); //输出 5
System.out.println(a>>35); //输出 5
如果 a 是 long 类型 那么 a >>n 就是 a >> (n%64)
long a = 40;
System.out.println(a>>3); //输出 5
System.out.println(a>>35); //输出 0
System.out.println(a>>67); //输出 5
注意 : 正数右移,前补位0(正数往右移,最小为0)
System.out.println(40>>31); //输出 0
System.out.println(Integer.toBinaryString(40>>31)); //输出 0
负数右移,前补位1(负数往右移,最大为-1)
System.out.println(-40>>31); //输出 -1
System.out.println(Integer.toBinaryString(-40>>31)); //输出 1111 1111 1111 1111 1111 1111 1111 1111
负数右移,并不仅仅是除以2
System.out.println(-5>>1); //输出 -3
System.out.println(Integer.toBinaryString(-5)); //输出 1111 1111 1111 1111 1111 1111 1111 1011
System.out.println(Integer.toBinaryString(-5>>1)); //输出 1111 1111 1111 1111 1111 1111 1111 1101
>>>无符号右移:
按位做平移,前补位用0(正负数都一样)
如果 a 是 byte、short、int 类型 那么 a >>> n 就是 a >>> (n%32)
int a = 40;
System.out.println(a>>>3); //输出 5
System.out.println(a>>>35); //输出 5
如果 a 是 long 类型 那么 a >>> n 就是 a >>> (n%64)
long a = 40;
System.out.println(a>>>3); //输出 5
System.out.println(a>>>35); //输出 0
System.out.println(a>>>67); //输出 5
版权声明:转载请注明出处:http://www.cnblogs.com/lkcc/
请读者亲自试一试代码,以免文章有误而误解。
谢谢读看!
java 移位运算的更多相关文章
- 【原创】Java移位运算
学习移位运算,首先得知道参与移位运算的类型的位数,那先来复习下Java基础类型的占位数吧. Java基础类型 Java基础类型总结一览表 类型 二进制位数 最大值 最小值 初始化值 表示形式 带符号 ...
- [JAVA]移位运算(左移<<,右移>>和无符号右移>>>)
一.背景知识 整数在内存中是以二进制的形式存在的,而且存的是该整数的补码.最高位代表符号位,正数为0,负数为1 正数的补码是其二进制本身,负数的补码则是 符号位保持1不变,其他位按位取反再加1,+0和 ...
- Java移位运算
java中移位运算符有三种“<<”.“>>”.“>>>”,没有“<<<”运算符. “<<”运算符将二进制位进行左移,低位用0来填 ...
- Java 移位运算、符号位扩展
类型取值范围 short 是1字节,即8位.而且 Java 中只有有符号数,所以最大值 0111,1111=2^7-1. 同时计算机中以补码形式存负数,所以可以多表示一个数,则最小值 1000,000 ...
- java移位运算的用途
参考下面这篇文章 http://blog.csdn.net/gaowen_han/article/details/7163104 http://jinguo.iteye.com/blog/540150 ...
- JAVA:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题(5)
一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...
- Java学习第五篇:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题
一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...
- Java中的位运算符、移位运算
一.位运算 Java中有4个位运算,它们的运算规则如下: (1)按位与 (&) :两位全为1,结果为1,否则为0: (2)按位或 (|) :两位有一个为1,结果为1,否则为0: (3) ...
- java中位运算和移位运算详解
一.位运算 (1)按 位 与 & 如果两个相应的二进制形式的对应的位数都为1,则结果为1,记为同1为1,否则为0.首先我们看一下对正数的运算 分别看一下正数和负数的具体运算步骤 ...
随机推荐
- es6笔记1^_^let、string、number、math
ECMAScript是一种由Ecma国际(前身为欧洲计算机制造商协会,英文名称是European Computer Manufacturers Association)通过ECMA-262标准化的脚本 ...
- MJRefresh框架使用及说明
一. MJRefresh的类解释. 1.MJRefreshComponent 所有刷新控件的基类别.(component: 成分,组件) 2.MJRefreshNormalH ...
- Perception(0-1.1)
The perception modules run in the context of the process Cognition. They detect features in the imag ...
- action = "#" 是什么意思 在HTML语言中
action = "#" 是form标签的属性,代表提交数据到本页,如:// 提交数据到a.aspx页面<form action="a.aspx"> ...
- springmvc-interceptor(拦截器)
在大配置中配置拦截器代码如下: <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**" ...
- 百度的hao123.com篡改浏览器首页,解决办法
快捷方式右键找到chrome.exe, 把chorme.exe修改成别的名字例如 chromeFuckHao123.exe 就OK了. hao123是用病毒的形式查找chrome.exe然后进程注入的 ...
- Linux下的暴力密码在线破解工具Hydra安装及其组件安装-使用
Linux下的暴力密码在线破解工具Hydra安装及其组件安装-使用 hydra可以破解: http://www.thc.org/thc-hydra,可支持AFP, Cisco AAA, Cisco a ...
- torisegit 保存帐号密码
设置 -> git 编辑本地 .git/config 增加 [credential] helper = store
- 使用Nginx+Lua(OpenResty)开发高性能Web应用
摘自(http://jinnianshilongnian.iteye.com/blog/2280928) 在互联网公司,Nginx可以说是标配组件,但是主要场景还是负载均衡.反向代理.代理缓存.限流等 ...
- CodeForces 669C Little Artem and Matrix GNU
模拟. 把操作记录一下,倒着复原回去. #pragma comment(linker, "/STACK:1024000000,1024000000") #include<cs ...