Heim Backend-Entwicklung C++ Warum unterscheidet sich die Gleitkomma-Arithmetik zwischen x86 und x64 in Visual Studio 2010?

Warum unterscheidet sich die Gleitkomma-Arithmetik zwischen x86 und x64 in Visual Studio 2010?

Nov 01, 2024 am 05:04 AM

Why does floating-point arithmetic differ between x86 and x64 in Visual Studio 2010?

Diskrepanz bei der Gleitkomma-Arithmetik zwischen x86 und x64

In Visual Studio 2010 entsteht ein deutlicher Unterschied in der Gleitkomma-Arithmetik zwischen x86- und x64-Builds entsteht beim Vergleich der Werte bestimmter Ausdrücke. Diese Ungleichheit manifestiert sich im folgenden Code:

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;
Nach dem Login kopieren

x86- und x64-Architekturen behandeln den zweiten Ausdruck, bLarger2, unterschiedlich. Im x86-Build wird bLarger2 als „true“ ausgewertet, während es im x64-Build als „false“ ausgewertet wird. Diese Ungleichheit hat ihren Ursprung in der Berechnung des Ausdrucks (a * c) in Gleitkommaoperationen.

Ursprünge der Ungleichheit

Die Wurzel der Ungleichheit liegt im Unterschied Gleitkommaeinheiten, die von den beiden Architekturen verwendet werden: x87 für x86 und SSE für x64. Der grundlegende Unterschied zwischen den beiden Einheiten ist ihre Präzision. Die x87-Einheit verwendet standardmäßig eine höhere als einfache Genauigkeit (normalerweise doppelte Genauigkeit), während die SSE-Einheit ausschließlich mit einfacher Genauigkeit arbeitet.

Behebung der Diskrepanz

Um das zu beheben Bei Abweichungen kann die Genauigkeit der x87-Einheit manuell so konfiguriert werden, dass sie mit der der SSE-Einheit übereinstimmt. Dies kann in 32-Bit-Code erreicht werden, indem Folgendes ausgeführt wird:

_controlfp(_PC_24, _MCW_PC);
Nach dem Login kopieren

Durch Festlegen der Genauigkeit auf einfache Genauigkeit wird die Auswertung von (a * c) im bLarger2-Ausdruck an die von x64 angepasst Build, was dazu führt, dass sowohl bLarger1 als auch bLarger2 auf false gesetzt werden.

Fazit

Der Unterschied in der Gleitkomma-Arithmetik zwischen x86- und x64-Builds ergibt sich aus den unterschiedlichen Genauigkeitsstufen der x87- und SSE-Gleitkommaeinheiten. Durch die manuelle Steuerung der Präzision der x87-Einheit, um sie an die der SSE-Einheit anzupassen, kann die Diskrepanz beseitigt werden, wodurch eine konsistente Auswertung der Ausdrücke über beide Architekturen hinweg sichergestellt wird.

Das obige ist der detaillierte Inhalt vonWarum unterscheidet sich die Gleitkomma-Arithmetik zwischen x86 und x64 in Visual Studio 2010?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert? Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert? Mar 03, 2025 pm 05:52 PM

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert?

GULC: C -Bibliothek von Grund auf neu gebaut GULC: C -Bibliothek von Grund auf neu gebaut Mar 03, 2025 pm 05:46 PM

GULC: C -Bibliothek von Grund auf neu gebaut

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte Mar 03, 2025 pm 05:53 PM

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die? Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die? Mar 03, 2025 pm 05:53 PM

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die?

eindeutiger Gebrauch und Phrasenfreigabe eindeutiger Gebrauch und Phrasenfreigabe Mar 03, 2025 pm 05:51 PM

eindeutiger Gebrauch und Phrasenfreigabe

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher? Wo ist der Rückgabewert der C -Sprachfunktion im Speicher? Mar 03, 2025 pm 05:51 PM

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher?

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)? Mar 12, 2025 pm 04:50 PM

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)?

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient? Mar 12, 2025 pm 04:52 PM

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient?

See all articles