検索
ホームページJava&#&チュートリアルJava での浮動小数点の直接の等価比較に問題があるのはなぜですか?また浮動小数点を正しく比較するにはどうすればよいですか?

Why is Direct Floating-Point Equality Comparison in Java Problematic, and How Can We Correctly Compare Floats?

Java における浮動小数点の等価比較の落とし穴

Java 開発者は、等価演算子 (==) を使用して浮動小数点を比較するときに混乱に遭遇することがよくあります。 -ポイント番号。ドキュメントには浮動小数点比較の有効性が記載されているにもかかわらず、静的解析ツールはそのような比較に誤りがあるとフラグを立てます。

Float では == が問題となるのはなぜですか?

浮動小数点数10 進数値を一定レベルの精度でバイナリ形式で表します。この固有の不正確さにより、浮動小数点計算の結果には小さな誤差が含まれる可能性があります。これらのエラーは、等価性チェックで予期しない比較につながる可能性があります。

浮動小数点を比較する正しい方法

浮動小数点の等価性の落とし穴を軽減するには、以下を使用することをお勧めします。代わりに、公差ベースのアプローチを使用します。推奨される解決策は、2 つの浮動小数点間の絶対差が、イプシロンとして知られる事前定義されたしきい値より小さいかどうかをテストすることです。推奨されるコードは次のとおりです。

if(Math.abs(sectionID - currentSectionID) <p>イプシロンは非常に小さな数値で、通常は約 0.00000001 であり、許容可能な不精度レベルを表します。このアプローチでは、浮動小数点計算における軽微なエラーが許容され、正確な等価性チェックが保証されます。この変更された比較を使用すると、Java で浮動小数点の等価性のために == を使用することによる落とし穴を回避できます。</p>

以上がJava での浮動小数点の直接の等価比較に問題があるのはなぜですか?また浮動小数点を正しく比較するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。