Java 无中间变量交换大整数技巧
时间:2026-05-12 13:57:26 216浏览 收藏
本文揭秘了用异或运算(^)原地交换Java基本整数类型(如int、long)的底层原理与实现细节,强调其依赖a^a=0和a^0=a的数学恒等式,但明确指出该技巧对BigInteger和Integer等不可变类型完全失效——前者不支持位运算符重载,后者涉及拆箱装箱且无法真正“原地”修改;更关键的是,所谓“大整数”一旦超出long范围,唯一可行的BigInteger必然要求临时变量参与交换,而现代Java开发中,可读性、安全性和JVM优化已让传统异或交换沦为过时陷阱,临时变量才是简洁、可靠、符合工程实践的首选方案。

可以使用逻辑异或(^)实现两个整数变量的原地交换,但仅适用于 基本类型 int(或 long 等整数类型),且需满足特定前提。对“大型整数”需特别注意:若指 java.math.BigInteger,则 无法直接用 ^ 交换,因其不支持位运算符重载,且是不可变对象。
适用场景:基本整数类型(int、long)
异或交换依赖恒等式:a ^ a = 0 和 a ^ 0 = a,推导如下:
- a = a ^ b
- b = a ^ b → 即 (a^b) ^ b = a
- a = a ^ b → 即 (a^b) ^ a = b
代码示例:
int x = 123456; int y = 789012; x = x ^ y; y = x ^ y; // 此时 y 变为原 x x = x ^ y; // 此时 x 变为原 y
不适用场景:BigInteger 或包装类(Integer)
BigInteger 没有 ^ 运算符支持,也不能通过位运算修改其值(它是不可变的)。试图写 bigA = bigA.xor(bigB) 是合法的,但必须显式赋值,且无法用三步异或完成原地交换——因为每次调用 xor() 都返回新对象,仍需中间引用或额外变量来暂存。
同理,Integer 等包装类型是不可变的,且 ^ 操作会自动拆箱为 int,但交换后重新装箱会产生新对象,引用本身仍需更新,无法规避变量赋值操作。
为什么不能用于“大型”数值本身?
Java 的 int 最大为 2³¹−1,long 为 2⁶³−1,超出即溢出。所谓“大型整数”若指超过 long 范围的数,唯一选择是 BigInteger,而它不支持 ^ 作为中缀运算符,也没有就地修改能力。此时交换必须依赖临时变量(哪怕只是方法内局部引用),这是语言模型决定的,非技巧可绕过。
实际建议:优先使用临时变量
尽管异或交换在理论上避免了额外空间,但它:
– 可读性差,易引发维护困惑;
– 对相同变量操作(如 x ^= y ^= x ^= y)行为未定义(Java 不保证赋值顺序);
– 无法处理 null(对 Integer)或任意对象;
– 现代 JVM 优化极好,临时变量几乎无性能开销。
推荐写法:
int temp = x; x = y; y = temp;
简洁、安全、符合直觉。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
150 收藏
-
225 收藏
-
125 收藏
-
436 收藏
-
500 收藏
-
121 收藏
-
351 收藏
-
335 收藏
-
150 收藏
-
289 收藏
-
216 收藏
-
261 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习