


2 つの float64 の間に不一致があるのはなぜですか?
次の Go スニペットを考えてみましょう:
fmt.Println(912 * 0.01) fmt.Println(float64(912) * 0.01)
正しく理解しながら2 行目には 9.120000000000001 が出力されます。最初の行がなぜ末尾に ...01 を付けずに 9.12 を出力するのか不思議に思うかもしれません。
その答えは、仕様で定義されている Go の定数式の処理にあります。
定数式は常に評価されます。その通り;中間値と定数自体は、言語で事前に宣言された型でサポートされているよりも大幅に大きい精度を必要とする場合があります。
912 * 0.01 は定数式であるため、非常に高い精度で評価されます。この式の結果を引数として fmt.Println() に渡すときも、これと同じ精度が維持されます。本質的に、 fmt.Println(912 * 0.01) は fmt.Println(9.12) であるかのように動作します。9.12 は評価された式の正確な表現です。
対照的に、912 を明示的に float64 にキャストすると、 2 行目では、浮動小数点乗算の両方のオペランドが暗黙的に float64 にキャストされます。 0.01 は float64 では正確に表現できないため、精度の低下が発生し、出力に ...01 が存在します。
したがって、結果の違いは、定数式の評価中に保持される精度と暗黙的な精度に起因します。 float64(912) * 0.01.
に関係するキャスト以上がGo が `912 * 0.01` に対して 9.12 を出力するのに、`float64(912) * 0.01` に対して 9.120000000000001 を出力するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています

この記事では、コードのランタイム操作に使用されるGoの反射パッケージについて説明します。シリアル化、一般的なプログラミングなどに有益です。実行やメモリの使用量の増加、賢明な使用と最高のアドバイスなどのパフォーマンスコストについて警告します

この記事では、go.modを介してGOモジュールの依存関係の管理、仕様、更新、競合解決をカバーすることについて説明します。セマンティックバージョンや定期的な更新などのベストプラクティスを強調しています。

この記事では、GOでテーブル駆動型のテストを使用して説明します。これは、テストのテーブルを使用して複数の入力と結果を持つ関数をテストする方法です。読みやすさの向上、重複の減少、スケーラビリティ、一貫性、および


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ホットトピック









