integer.tostring 能直接转进制因其第二个参数为合法进制基数(2–36),但常因传入非法 radix(如0、1、37)、负数、字符串或类型不匹配而出错;它不加前缀、不处理补码、仅支持 int,负数按绝对值转换并加“-”号。

Integer.toString 为什么能直接转进制,但又常出错
因为 Integer.toString 的第二个参数是进制基数(radix),不是“目标进制名称”,填错值就会返回十进制原样或抛 NumberFormatException。比如传 0、1、37 都非法——合法范围是 2 到 36。
常见错误现象:
- 想转二进制却写了
Integer.toString(42, 2)→ 实际是对的,但很多人误写成Integer.toString(42, "binary")(编译不过) - 用负数当 radix → 运行时报
IllegalArgumentException - 传
null或字符串 → 方法不接受,只能是int和int
实操建议:
- 二进制用
Integer.toString(x, 2),八进制用Integer.toString(x, 8),十六进制用Integer.toString(x, 16) - 注意:结果不含前缀(如
0b、0x),要自己拼接 - 对负数,它会先取绝对值再转换,然后在开头加
-,例如Integer.toString(-10, 2)得到"-1010"
想带前缀(0x / 0b)怎么办
Integer.toString 不负责加前缀,这是它的设计边界。Java 没有内置方法一步到位,得手动拼或换工具类。
立即学习“Java免费学习笔记(深入)”;
实操建议:
- 十六进制补
0x:"0x" + Integer.toString(x, 16).toLowerCase() - 二进制补
0b:"0b" + Integer.toString(x, 2) - 注意大小写:默认
toString返回小写 a–f;要大写就用toUpperCase() - 如果需要零填充(如固定 8 位),不能靠
toString,得用String.format("%8s", ...).replace(' ', '0')或Integer.toBinaryString等专用方法
Integer.toBinaryString / toOctalString / toHexString 更好用?
这三个是特化方法,和 Integer.toString(x, N) 行为一致,但更语义清晰、少输参数、且 IDE 更易提示。性能上无差别,都是调同一套底层逻辑。
实操建议:
- 明确转二进制时,优先用
Integer.toBinaryString(x),比Integer.toString(x, 2)少打两个字符,也不怕 radix 输错 - 它们都不处理负数的补码表示——全按“带符号绝对值”转,即
Integer.toBinaryString(-1)返回"1",不是 32 个1 - 真要获取补码字符串(如调试位操作),得用
Integer.toBinaryString(x & 0xFFFFFFFF)强制转无符号
超出 int 范围的数字怎么转进制
Integer.toString 只吃 int,遇到 long、BigInteger 就得换方法,否则隐式截断出错。
实操建议:
-
long用Long.toString(x, radix),支持同样2–36范围 -
BigInteger用bigInt.toString(radix),这个radix也限2–36,但能处理任意长度整数 - 别用
Integer.toString((int) someLong)强转——高位信息直接丢,连警告都没有 - 从字符串反向解析时,也要匹配类型:
Integer.parseInt(s, 16)会溢出报NumberFormatException,这时该用Long.parseLong或new BigInteger(s, 16)
进制转换本身简单,麻烦的是边界:负数怎么表、前缀谁来加、类型越界有没有感知、补码要不要显式算。这些地方一不留神,输出看着像对的,实际逻辑已经偏了。










