Java处理长数字需用下划线分隔符提升可读性(编译期忽略)、优先选long防溢出、精确计算用BigDecimal(字符串构造)、长数字输入统一按String解析。
Java中处理长数字,关键在于正确使用数字字面量分隔符、选择合适的数据类型,并注意浮点数精度问题。直接写1000000000不如写1_000_000_000清晰,但更关键的是:分隔符只是编译期语法糖,不改变数值本身;而类型选错或混用浮点运算,才真正导致精度丢失。
下划线_可在数字字面量中任意非开头/结尾、非小数点两侧的位置使用,仅用于提高可读性,编译后被完全忽略。
int x = 1_234_567;、long y = 0x1F_FFFF_FFFF_L;、double z = 123_456.789_012;
int a = _123;(开头)、int b = 123_;(结尾)、double c = 123_.45;(紧邻小数点)String.valueOf()、toString()等无影响——输出永远不含下划线long而非int
Java默认整数字面量是int型,超范围(±2³¹)会编译报错;大整数必须显式声明为long(加L或l)。
int i = 2_147_483_647; ✅ 最大int值(2³¹−1)int j = 2_147_483_648; ❌ 编译失败:超出int范围long k = 2_147_483_648L; ✅ 正确:加L明确为longlong,避免隐式转换溢出float/double做精确计算double和float基于二进制IEEE 754标准,无法精确表示大多数十进制小数(如0.1),累积误差不可避免。
double sum = 0.1 + 0.2; 结果是0.30000000000000004,不是0.3
BigDecimal,构造时传字符串(new BigDecimal("0.1")),禁用double参数构造器BigDecimal运算需调用add()、multiply()等方法,不可用+、*操作符用户输入或JSON/CSV中的长数字(如19位手机号、16位银行卡号)极易因类型误判丢失精度,应统一按字符串接收,再按需转为数值类型。
int id = Integer.parseInt(input); → 可能抛NumberFormatException或截断String idStr = input.trim(); 然后根据业务决定是否转Long.parseLong(idStr)或保留字符串(如身份证号含X、银行卡号不做算术)Integer或Long,若字段可能超long范围(如128位哈希),应配置为String类型反序列化基本上就这些。分隔符让代码更易读,类型选对防止溢出,BigDecimal守住精度底线,字符串兜底保数据完整——不复杂但容易忽略。