1.为什么不是1.51?输出的是1.50
2.decimalformat括号里的字符串代表了什么意思?有模板吗?如果是别的格式应该怎么写
3.为什么要用#号而不是0.00?如果是#好的话,当a是0.505的时候有bug
double a =1.505; BigDecimal bd = new BigDecimal(a); System.out.println(new DecimalFormat("#.00").format(bd));
ringa_lee
まず第一に、問題を指摘します。BigDecimal を構築するときは、浮動小数点数 (double、float) を使用しないようにしてください。ポイント番号はコンピュータにあります。 ストレージの精度が低いという問題があります。たとえば、次のコードを作成します: BigDecimal 的时候,尽量不要使用浮点数(double,float),因为浮点数在计算机中的存储存在精度缺失问题。比如你的写的代码:
BigDecimal
double
float
public static void main(String[] args) throws Exception { double a = 1.505; BigDecimal bd = new BigDecimal(a); System.out.println("bd: " + bd.toString()); }
运行结果:
可以看到,浮点数 1.505 在计算机中没法存储的 —— 具体原因如果不知道,请自行搜索 “浮点数精度缺失问题”
第二,如果需要输出 1.51,即常说的 “四舍五入”,那么需要指定 DecimalFormat 的舍入模式:
DecimalFormat
public static void main(String[] args) throws Exception { BigDecimal bd = new BigDecimal("1.505"); System.out.println("bd: " + bd.toString()); DecimalFormat df = new DecimalFormat("#.00"); df.setRoundingMode(RoundingMode.HALF_UP); System.out.println("format: " + df.format(bd)); }
如果不了解 RoundingMode 的用法,请自行搜索 “RoundingMode 的用法”
RoundingMode
第三,关于 DecimalFormat リーリー 実行結果:
リーリー
まず第一に、問題を指摘します。
BigDecimal
を構築するときは、浮動小数点数 (double
、float
) を使用しないようにしてください。ポイント番号はコンピュータにあります。 ストレージの精度が低いという問題があります。たとえば、次のコードを作成します:BigDecimal
的时候,尽量不要使用浮点数(double
,float
),因为浮点数在计算机中的存储存在精度缺失问题。比如你的写的代码:运行结果:
可以看到,浮点数 1.505 在计算机中没法存储的 —— 具体原因如果不知道,请自行搜索 “浮点数精度缺失问题”
第二,如果需要输出 1.51,即常说的 “四舍五入”,那么需要指定
DecimalFormat
的舍入模式:运行结果:
如果不了解
RoundingMode
的用法,请自行搜索 “RoundingMode 的用法”第三,关于
浮動小数点数 1.505 がコンピューターに保存できないことがわかります - 具体的な理由がわからない場合は、自分で検索してください 🎜「浮動小数点数の精度が欠落している問題」🎜🎜 🎜次に、1.51 を出力する必要がある場合 (これは「丸め」と呼ばれることが多い)、DecimalFormat
リーリー 実行結果:DecimalFormat
の丸めモードを指定する必要があります。 🎜 リーリー 🎜実行結果:🎜 🎜
RoundingMode
の使用法がわからない場合は、🎜「RoundingMode の使用法」を検索してください🎜🎜 🎜第三に、DecimalFormat
の括弧内の文字列の意味については、🎜「DecimalFormat の使用法」を検索してください🎜🎜リーリー