Absolvovanie plavák na funkciu v C++ sa mení presnosť

0

Otázka

To je veľmi noob otázka, ale som zvedavý, prečo za to: -Ak som debug nasledujúce C++ kód:

void floatreturn(float i){
      //nothing
}

int main(){
    float a = 23.976;
    floatreturn(a);
    return 0;
}

Monitorovanie prešiel hodnoty, zdá sa, 23.9759998 pri vstupe floatreturn. Ako výsledok, spracovanie hodnota v funkcia bude vyžadovať manuálne meniť presnosť. Je tam dôvod na to, a žiadny spôsob, ako sa mu vyhnúť?

c++ floating-point
2021-11-24 04:32:57
1

Najlepšiu odpoveď

0

Problém sa stalo pred floatreturn(a);.
To sa stalo na float a = 23.976;
floatreturn(a); je irelevantné.

Tam sú o 2^32 rôznych hodnôt, ktoré float môžete kódovať presne. 23.976 nie je jedným z nich. Najbližšie encodable float je o 23.9759998...

Ak chcete zabrániť, použite hodnoty, ktoré môžete presne kódujú ako float alebo tolerovať, že je blízko - o 1 časť 224

2021-11-24 16:43:03

Vďaka Označiť za odkaz a chux pre stručnú odpoveď.
mv_p

Len jeden viac vzdelávacích miesto pre mňa: prečo cout predvolené, ak chcete presnosťou na 3 desatinné miesta, ak sme dotlač, variabilný bez nastavenie presnosti pre výstup? Som si, že ukladanie plavák vždy vrátiť najbližšie binárne float je to možné, a že cout je zaokrúhľovania.
mv_p

@mv_p Aký bol presný výstup ste videli?
chux - Reinstate Monica

s jednoduchý "float x = 23.976; cout << x;" ja pozrite si časť "23.976"
mv_p

V iných jazykoch

Táto stránka je v iných jazykoch

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................