网站首页 > java教程 正文
好程序员Java学习路线分享Java中的位移运算,在Java中,位移运算属于基本运算,符号是<<和>>,即向左位移和向右位移。在Java中只有整数才能位移,所以其他的不考虑,位移运算是将整数在内存中表示的二进制进行位移,所以在Java中分为正数和负数的位移。
对于正数来说,向左位移,即<<相当于乘以2,移动多少次即乘以多少次2,例如5<<2即5 * 2 * 2 = 20,而向右位移即>>相当于除以2,注意是整数除以整数。例如 5 >> 1 即5/2=2。
下面举例说明:
5<<1,我们以int为例:
数字5
int型的二进制表示为: 0000 0000 0000 0000 0000 0000 0000 0101
向左移1位即: 0000 0000 0000 0000 0000 0000 0000 1010 (后位补0)
所以结果为:数字10
5>>1,我们以int为例:
数字5
int型的二进制表示为: 0000 0000 0000 0000 0000 0000 0000 0101
向右移1位即: 0000 0000 0000 0000 0000 0000 0000 0010 (高位补0)
所以结果为:数字2
所以对于正数,可以随意使用位移,与乘除几乎没有结果的区别,而且性能更优。
而对于负数来说,Java中的位移应该谨慎使用,因为位移运算在Java中称为带符号的位移。那么到底带符号的位移是如何计算的呢,下面直接举例说明:
-5<<1,我们以int为例,由于负数在内存是以补码存在,请看:
数字-5
int型的二进制原码表示为: 1000 0000 0000 0000 0000 0000 0000 0101
而其反码为:1111 1111 1111 1111 1111 1111 1111 1010
补码为:1111 1111 1111 1111 1111 1111 1111 1011
向左移1位即结果为:1111 1111 1111 1111 1111 1111 1111 0110 (后位补0)
将结果计算反码为:1111 1111 1111 1111 1111 1111 1111 0101
将结果计算原码为:1000 0000 0000 0000 0000 0000 0000 1010
所以结果为:数字-10
看起来好像还是乘以2,但是换个数字来试试:
例如数字的二进制如果为:1110 0000 0000 0000 0000 0000 0000 0001
而其反码为:1001 1111 1111 1111 1111 1111 1111 1110
补码为:1001 1111 1111 1111 1111 1111 1111 1111
向左移1位即结果为:0011 1111 1111 1111 1111 1111 1111 1110
这个结果的最高位是0,所以必然是个正数,所以结果并非想象的乘以2。
如果是右移,那么高位会补1,结果一样不算正常,例如:
-5>>1,我们以int为例,由于负数在内存是以补码存在,请看:
数字-5
int型的二进制原码表示为: 1000 0000 0000 0000 0000 0000 0000 0101
而其反码为:1111 1111 1111 1111 1111 1111 1111 1010
补码为:1111 1111 1111 1111 1111 1111 1111 1011
向右移1位即结果为:1111 1111 1111 1111 1111 1111 1111 1101 (高位补1)
将结果计算反码为:1111 1111 1111 1111 1111 1111 1111 1100
将结果计算原码为:1000 0000 0000 0000 0000 0000 0000 0011
所以结果为:数字-3
而在Java中,-5除以2应该结果为-2,但是位移却为-3。
另外,如果是下面的例子:
-1>>1,我们以int为例,由于负数在内存是以补码存在,请看:
数字-1
int型的二进制原码表示为: 1000 0000 0000 0000 0000 0000 0000 0001
而其反码为:1111 1111 1111 1111 1111 1111 1111 1110
补码为:1111 1111 1111 1111 1111 1111 1111 1111
向右移1位即结果为:1111 1111 1111 1111 1111 1111 1111 1111 (高位补1)
所以结果不用慢慢算就知道为:数字-1
所以对于-1来说,无论怎么右移,结果还是-1,而如果是除以2,结果是0。
最后总结一句,如果是正数,当可以使用位移运算时可以尽量使用,能提升性能,而对于负数来说,还是尽量别用吧,结果与除法相差太远。
猜你喜欢
- 2024-10-18 Java 中的移位运算符(Shift Operator)
- 2024-10-18 「每日分享」把Map中的hash()分析的最透彻的文章
- 2024-10-18 从bitmap到布隆过滤器,再到高并发缓存设计策略
- 2024-10-18 Java基础入门(运算符)(java运算符的含义)
- 2024-10-18 Day03-Java运算(三年级混合运算练习题)
- 2024-10-18 浅谈java中的数学运算(java的数学公式有哪些)
- 2024-10-18 全网分析Map中hash方法最透彻的一篇文章
- 2024-10-18 为什么Java String哈希乘数为31?(java中string是什么数据类型)
- 2024-10-18 Java精确运算高位数数字(java计算精度问题)
- 2024-10-18 排列组合算法真厉害,傻瓜都能学会!
你 发表评论:
欢迎- 07-15采用Oracle OSB总线进行服务注册和接入
- 07-15javaEE 新闻管理系统 oracle11+tomcat6
- 07-15从Oracle演进看数据库技术的发展(oracle数据库发展史)
- 07-15如何升级oracle数据库安全补丁(oraclepsu补丁升级)
- 07-15【权威发布】关于Oracle WebLogic Server未授权远程代码执行高危漏洞的预警通报
- 07-15【mykit-data】 数据库同步工具(数据库表同步工具)
- 07-15[Java速成] 数据库基础,Connector/J、JDBC、JPA的关系(day 7)
- 07-15Google前工程主管“入住”Oracle(google浏览器找不到以前的书签)
- 最近发表
-
- 采用Oracle OSB总线进行服务注册和接入
- javaEE 新闻管理系统 oracle11+tomcat6
- 从Oracle演进看数据库技术的发展(oracle数据库发展史)
- 如何升级oracle数据库安全补丁(oraclepsu补丁升级)
- 【权威发布】关于Oracle WebLogic Server未授权远程代码执行高危漏洞的预警通报
- 【mykit-data】 数据库同步工具(数据库表同步工具)
- [Java速成] 数据库基础,Connector/J、JDBC、JPA的关系(day 7)
- Google前工程主管“入住”Oracle(google浏览器找不到以前的书签)
- Oracle数据库云服务系列新增前所未有的企业级功能
- 直播预告丨如何实现Oracle存储过程到java的一键转化
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)