Java位移运算符详解:左移、右移与无符号右移计算方法
时间:2026-03-04 13:33:51 253浏览 收藏
本文深入解析Java中三大位移运算符(左移>、无符号右移>>>)的核心机制与实战陷阱:揭示右移如何依据符号位或强制补零、位移量自动对类型长度取模的隐式行为、运算符优先级低于加减法所导致的括号缺失风险,以及无符号右移在哈希计算、位掩码提取等场景中的不可替代性;同时提醒开发者警惕负数右移的非直观结果、long类型截断问题,并强调位移并非万能优化——它直通CPU指令,但仅应在真正需要比特级控制或高性能底层开发时使用,而非盲目替代乘除法。

左移 << 就是乘以 2 的幂,但要注意溢出
左移的本质是把二进制位整体向左挪,右边空出来的补 0。每左移 1 位,等价于乘以 2(对正数而言)。比如 5 << 1 是 10,5 << 2 是 20。
但别忘了 Java 中整数有固定位数:int 是 32 位,long 是 64 位。左移太多会把高位“挤掉”,结果就不是数学上的乘法了:
1 << 31得到的是-2147483648(即0x80000000),因为符号位被置 1 了1 << 32对int来说等于1 << 0,因为 Java 规定只取位移量的低 5 位(32 位数)——所以32 % 32 == 0- 用
long时,位移量取低 6 位,1L << 64等价于1L << 0
右移 >> 会保留符号位,负数右移不等于除以 2
右移是把二进制位整体右挪,左边补的是**原符号位**(算术右移)。所以正数右移相当于向下取整的除法,但负数不是:
8 >> 1→4(✔️ 类似8 / 2)-8 >> 1→-4(✔️ 看起来也像除法)-7 >> 1→-4(❌ 不是-3.5向下取整,而是二进制补码右移后补 1:原码11111001→ 补码右移 →11111100= -4)- 它和数学除法不等价,尤其在负数且不能整除时;JVM 不保证编译器会用右移替代除法优化
无符号右移 >>> 强制补 0,适合处理纯位数据
这个操作符不管符号位,一律在左边补 0,所以结果永远是非负的。它不表示“数学除法”,而是一种纯粹的位操作:
-1 >>> 1→2147483647(0x7FFFFFFF),因为-1的补码全是 1,右移 1 位再补 0,高位变成 0)- 常用于哈希计算、位掩码提取、网络字节序处理等场景,比如从
int中取低 8 位作为 byte:(value >>> 24) & 0xFF - 对
long使用时注意:long值如果赋给int变量会截断,别漏掉L后缀或强转
位移运算符优先级比加减还低,不加括号容易出错
很多人写 a << b + c 想表达 “a 左移 (b+c) 位”,但实际是 a << b 再加 c,因为 + 优先级高于 <<。
- 查 JLS 运算符优先级表:
<<、>>、>>>和+、-是不同层级,+更高 - 正确写法必须加括号:
a << (b + c) - 类似地,
a + b >> c等价于(a + b) >> c,但如果你本意是a + (b >> c),那就得显式括起来 - IDE 一般会警告这类歧义,但命令行编译不会——靠人眼盯住括号
位移不是语法糖,它直接映射到 CPU 指令,但现代 JVM 对 / 和 * 也有高度优化。别为了“看起来快”硬套位移,除非你在写高性能底层逻辑或者明确要操作比特位。最常被忽略的其实是位移量对类型长度的取模行为,以及负数右移时补符号位带来的非直观结果。
今天关于《Java位移运算符详解:左移、右移与无符号右移计算方法》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
193 收藏
-
108 收藏
-
339 收藏
-
465 收藏
-
150 收藏
-
129 收藏
-
453 收藏
-
393 收藏
-
319 收藏
-
279 收藏
-
313 收藏
-
323 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习