Rumah pembangunan bahagian belakang C++ Mengapakah Keputusan Aritmetik Titik Terapung Berbeza Antara Binaan x86 dan x64 dalam MS VS 2010?

Mengapakah Keputusan Aritmetik Titik Terapung Berbeza Antara Binaan x86 dan x64 dalam MS VS 2010?

Oct 31, 2024 pm 07:36 PM

Why Do Floating-Point Arithmetic Results Differ Between x86 and x64 Builds in MS VS 2010?

Percanggahan Aritmetik Titik Terapung Antara x86 dan x64 dalam MS VS 2010

Dalam Microsoft Visual Studio 2010, operasi aritmetik titik terapung mempamerkan percanggahan antara binaan x86 dan x64, walaupun apabila dilaksanakan pada mesin 64-bit yang sama. Ini jelas dalam coretan kod berikut:

<code class="c++">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;</code>
Salin selepas log masuk

Pembolehubah boolean bLarger1 secara konsisten palsu, dengan d ditetapkan kepada 65.0 dalam kedua-dua binaan. Walau bagaimanapun, bLarger2 adalah palsu untuk x64 tetapi benar untuk x86.

Penyebabnya: x87 lwn. SSE

Percanggahan timbul daripada fakta bahawa binaan x86 menggunakan x87 unit titik terapung (FPU) manakala binaan x64 menggunakan unit Sambungan SIMD Penstriman (SSE). Perbezaannya terletak pada ketepatan pengiraan.

FPU x87 melakukan pengiraan dalam ketepatan dua kali secara lalai, walaupun semasa mengendalikan nilai ketepatan tunggal. Unit SSE, sebaliknya, melakukan pengiraan dalam ketepatan tunggal tulen. Akibatnya, pengiraan x87 adalah lebih tepat sedikit daripada pengiraan SSE.

Dalam kes ini, peningkatan ketepatan FPU x87 membawa kepada ralat pembundaran yang menyebabkan d kurang sedikit daripada 65.0. Ini menjadikan bLarger2 palsu untuk x86. Sebaliknya, pengiraan SSE dalam x64 menghasilkan nilai yang lebih tepat untuk d, menghasilkan nilai sebenar untuk bLarger2.

Penyelesaian untuk x86

Untuk memaksa binaan x86 untuk melakukan pengiraan dalam ketepatan tunggal, baris berikut boleh ditambah:

<code class="c++">_controlfp(_PC_24, _MCW_PC);</code>
Salin selepas log masuk

Ini menetapkan perkataan kawalan titik terapung untuk melaksanakan semua pengiraan dalam ketepatan tunggal. Dengan perubahan ini, kedua-dua bLarger1 dan bLarger2 akan ditetapkan kepada palsu untuk binaan x86 dan x64.

Kesimpulan

Percanggahan dalam aritmetik titik terapung antara x86 dan x64 binaan dalam MS VS 2010 berpunca daripada perbezaan antara x87 FPU dan unit SSE. Ketepatan x87 FPU yang lebih tinggi membawa kepada nilai yang sedikit berbeza berbanding dengan pengiraan ketepatan tunggal sebenar unit SSE. Dengan memaksa pengiraan ketepatan tunggal pada x86, pembangun boleh mengurangkan isu ini dan memastikan hasil yang konsisten merentas platform yang berbeza.

Atas ialah kandungan terperinci Mengapakah Keputusan Aritmetik Titik Terapung Berbeza Antara Binaan x86 dan x64 dalam MS VS 2010?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah jenis nilai yang dikembalikan oleh fungsi bahasa C? Apa yang menentukan nilai pulangan? Apakah jenis nilai yang dikembalikan oleh fungsi bahasa C? Apa yang menentukan nilai pulangan? Mar 03, 2025 pm 05:52 PM

Apakah jenis nilai yang dikembalikan oleh fungsi bahasa C? Apa yang menentukan nilai pulangan?

Gulc: Perpustakaan C dibina dari awal Gulc: Perpustakaan C dibina dari awal Mar 03, 2025 pm 05:46 PM

Gulc: Perpustakaan C dibina dari awal

Langkah Format Fungsi Fungsi C Langkah Penukaran Kes Langkah Format Fungsi Fungsi C Langkah Penukaran Kes Mar 03, 2025 pm 05:53 PM

Langkah Format Fungsi Fungsi C Langkah Penukaran Kes

Apakah definisi dan peraturan panggilan fungsi bahasa C dan apakah itu Apakah definisi dan peraturan panggilan fungsi bahasa C dan apakah itu Mar 03, 2025 pm 05:53 PM

Apakah definisi dan peraturan panggilan fungsi bahasa C dan apakah itu

Di manakah nilai pulangan fungsi bahasa C yang disimpan dalam ingatan? Di manakah nilai pulangan fungsi bahasa C yang disimpan dalam ingatan? Mar 03, 2025 pm 05:51 PM

Di manakah nilai pulangan fungsi bahasa C yang disimpan dalam ingatan?

Penggunaan dan perkongsian frasa yang berbeza Penggunaan dan perkongsian frasa yang berbeza Mar 03, 2025 pm 05:51 PM

Penggunaan dan perkongsian frasa yang berbeza

Bagaimanakah saya menggunakan algoritma dari STL (jenis, mencari, mengubah, dll) dengan cekap? Bagaimanakah saya menggunakan algoritma dari STL (jenis, mencari, mengubah, dll) dengan cekap? Mar 12, 2025 pm 04:52 PM

Bagaimanakah saya menggunakan algoritma dari STL (jenis, mencari, mengubah, dll) dengan cekap?

Bagaimana Perpustakaan Templat St Standard (STL) berfungsi? Bagaimana Perpustakaan Templat St Standard (STL) berfungsi? Mar 12, 2025 pm 04:50 PM

Bagaimana Perpustakaan Templat St Standard (STL) berfungsi?

See all articles