x86 と x64 の浮動小数点演算の違い
x86 と x64 の両方のアーキテクチャの MS VS 2010 で同一のコードを実行する場合(どちらも 64 ビット マシンで実行されている)、浮動小数点演算に顕著な違いが現れました。
次のコード スニペットを考えてみましょう:
float a = 50.0f; float b = 65.0f; float c = 1.3f; float d = a * c; bool bLarger1 = d < b; bool bLarger2 = (a * c) < b;
x86 ビルドと x64 ビルドの両方で、bLarger1 は残ります。 false (d は 65.0 に設定されます)。ただし、x64 ビルドでは bLarger2 は false ですが、x86 ビルドでは true です。
この不一致は、式 bLarger2 = (a * c)
から生じます。 b.生成されたコードは、x86 では評価が単精度 (通常は倍精度) を超える x87 ユニットで実行されるのに対し、x64 では純粋な単精度を実行する x64 ユニットで評価が実行されることを示しています。 -精度の計算。32 ビット ユニットが単精度で計算を実行できるようにするには、次の制御ワードを設定できます。_controlfp(_PC_24, _MCW_PC);
以上がx86 アーキテクチャと x64 アーキテクチャで浮動小数点演算が異なるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。