Go で浮動小数点数を文字列に書式設定する場合では、fmt.Sprintf() と strconv.FormatFloat() という 2 つの一般的なメソッドが登場します。ただし、最適なアプローチの選択は、特定の要件によって異なります。
使用法と相違点
fmt.Sprintf() と strconv.FormatFloat() はどちらも、同じ基礎となる文字列書式設定を使用します。機構。ただし、構文と柔軟性が異なります。
最適な方法の選択
丸め制御
strconv.FormatFloat() の最後の引数は bitSize として知られ、値の丸め方法を制御します。 。これは、元の浮動小数点値の有効ビット数を表し、データ型に基づいて正確な丸めを保証します。
例:
提供されたコード スニペットは両方を示しています。メソッド:
package main import ( "fmt" "strconv" ) func main() { var fAmt1 float32 = 999.99 var fAmt2 float32 = 222.22 // Calculate the result and format using Sprintf fResult := float32(int32(fAmt1*100) + int32(fAmt2*100)) / 100 sResult1 := fmt.Sprintf("%.2f", fResult) // Calculate the result and format using FormatFloat sResult2 := strconv.FormatFloat(float64(fResult), 'f', 2, 32) fmt.Println("Sprintf value:", sResult1) fmt.Println("FormatFloat value:", sResult2) }
結論
fmt.Sprintf() と strconv.FormatFloat() のどちらを選択するかは、アプリケーションの特定の要件によって異なります。一定の精度と効率的な書式設定には、 fmt.Sprintf() が適切なオプションです。可変精度と丸め制御のために、strconv.FormatFloat() は便利で柔軟なアプローチを提供します。
以上がGo で浮動小数点数をフォーマットするには、`fmt.Sprintf()` と `strconv.FormatFloat()` のどちらが適していますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。