ホームページ > バックエンド開発 > Golang > Go で JSON をマーシャリングするときに浮動小数点の精度を維持するにはどうすればよいですか?

Go で JSON をマーシャリングするときに浮動小数点の精度を維持するにはどうすればよいですか?

Susan Sarandon
リリース: 2024-11-29 19:20:12
オリジナル
1033 人が閲覧しました

How Can I Preserve Floating-Point Precision When Marshaling JSON in Go?

JSON マーシャリングでの浮動小数点精度の維持

Go では、json.Marshal() 関数が浮動小数点数から末尾のゼロを削除することがよくあります。 JSON シリアル化中。使用するアプリケーションが元の値の完全な精度を必要とする場合、これは問題となる可能性があります。

この問題を解決するには、浮動小数点値をカプセル化するカスタム データ型を定義することを検討してください。以下に例を示します。

type PreservedFloat float64

func (f PreservedFloat) MarshalJSON() ([]byte, error) {
    // Preserve trailing zeros in the JSON representation.
    if float64(f) == float64(int(f)) {
        return []byte(strconv.FormatFloat(float64(f), 'f', 1, 32)), nil
    }
    return []byte(strconv.FormatFloat(float64(f), 'f', -1, 32)), nil
}
ログイン後にコピー

この実装では:

  • PreservedFloat 型は、標準 float64 のラッパーとして機能します。
  • MarshalJSON メソッドはデフォルトをオーバーライドします。 JSON シリアル化動作。
  • 値が整数表現の場合 (いいえ小数部) の場合、末尾のゼロを保持するために小数点以下 1 桁で書式設定されます。
  • それ以外の場合、値は精度を指定せずに書式設定され、完全な精度を維持できます。

PreservedFloat を使用すると、浮動小数点値の JSON 表現を制御し、マーシャリング後でも精度を確実に維持できます。

以上がGo で JSON をマーシャリングするときに浮動小数点の精度を維持するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート