厳密に言えば、1.0/0.0
無限ではなく、未定義です。
デビッドが彼の答えで言っているように、フロートはそれが表すことができる最大の数と最小の数の範囲にない数を表現する方法を持っています。これらの値は、まとめて「数値ではない」または単にNaNと呼ばれます。NaNは、実際には無限大の計算(など)、有限であるがフロートが表すことができる範囲をオーバーフローする値(10 100 100など)、および1/0などの未定義の値からも発生する可能性があります。limx -> 0 ln2 x
浮動小数点数は、未定義の値、オーバーフロー、および無限大を明確に区別しません。その計算から得られるビットの組み合わせは異なります。「NaN」または「NotaNumber」を出力するだけでは、浮動小数点値がどのように表されるかを知らない人にとっては少し理解しにくいため、そのフォーマッターは「Infinity」または場合によっては「-Infinity」を出力します。 FP NaNが何であるかを知っているときの情報のレベル、および知らないときは何らかの意味があります。
整数には、浮動小数点NaNに匹敵するものはありません。1/0を実行するときに整数が取る意味のある値がないため、残っている唯一のオプションは例外を発生させることです。
機械語で記述された同じコードは、Java例外に相当する割り込みを呼び出すか、最後の計算がゼロ除算であることを示すグローバル値となる条件レジスタを設定することができます。利用可能なものは、プラットフォームによって少し異なります。