起因
最近遇到从Excel读取电话信息时,取出的数据是Double类型,需要转为字符串保存,问题来了,Double的toString方法返回的是科学计数法格式的字符串,如何取到原始串呢?
方法一: DecimalFormat
Double d = 111111111111111d;
DecimalFormat df = new DecimalFormat("#");
System.out.println(df.format(d));
缺点:只能转换整数,如果Double值是小数,不能根据小数位的变化而变化,不够通用;
方法二:String.format()
Double d = 111111111111111d;
System.out.println(String.format("%.0f", d));//保留0位小数
//实际调用的是java.util.Formatter类的format()方法
缺点和上面一样
方法三:BigDecimal
Double d = 111111111111111d;
BigDecimal bd = new BigDecimal(d.toString());
System.out.println(bd);
完美还原原始数值格式,大家如果有更好的方式可在评论区留言~
另:看Double源码发现,Java是可以除0的(浮点数可除零,整数不行),惊呆了!
POSITIVE_INFINITY
:正无穷大;NEGATIVE_INFINITY
:负无穷大;NaN
:非数字(Not-a-Number);
以上在JavaScript中也适用