小数精度での浮動小数点の書式設定
浮動小数点数を特定の小数桁数に書式設定することは、さまざまなプログラミング シナリオで一般的なタスクです。これを実現するために、広く使用されているアプローチの 1 つは、Java の BigDecimal クラスを利用することです。ただし、予期される戻り値の型が float の場合、BigDecimal を使用すると不正な結果が生じる可能性があります。
指定されたコード例では:
<code class="java">public static float Redondear(float pNumero, int pCantidadDecimales) { // the function is call with the values Redondear(625.3f, 2) BigDecimal value = new BigDecimal(pNumero); value = value.setScale(pCantidadDecimales, RoundingMode.HALF_EVEN); // here the value is correct (625.30) return value.floatValue(); // but here the values is 625.3 }</code>
この問題は、BigDecimal 値を変換して元の値に戻すときに発生します。フロート。この目的のために、次のように String.format メソッドを使用することをお勧めします。
String.format("%.2f", floatValue);
書式指定子 (%.2f) 内で希望の小数点以下の桁数を指定することで、書式設定された文字列を取得できます。指定された精度での float 値の表現。この場合、戻り値の型は String であることに注意してください。
以上がJava で 10 進精度で浮動小数点数をフォーマットするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。