C++-manipulaattorin tarkkuus toimintoa käytetään ohjaamaan liukulukuarvon lähtövirran näytön numeroiden määrää.
Tämä manipulaattori on ilmoitettu otsikkotiedostossa.
Syntaksi
/*unspecified*/ setprecision (int n);
Parametri
n : uusi arvo desimaalitarkkuudelle.
Palautusarvo
Tämä funktio palauttaa määrittelemättömän tyyppisen objektin. Setbase-toimintoa tulisi käyttää vain stream-manipulaattorina.
Data kilpailut
Virtaobjektia, johon se lisätään tai puretaan, muutetaan ja samanaikainen pääsy samaan stream-objektiin voi aiheuttaa datakilpailuja.
Poikkeukset
Objekti on kelvollisessa tilassa, jos jokin poikkeus heitetään.
Esimerkki 1
Katsotaanpa yksinkertaista esimerkkiä setprecisionin käytön havainnollistamiseksi:
#include // std::cout, std::fixed #include // std::setprecision using namespace std; int main () { double f =3.14159; cout << setprecision(5) << f << ' '; cout << setprecision(9) << f << ' '; cout << fixed; cout << setprecision(5) << f << ' '; cout << setprecision(9) << f << ' '; return 0; }
Lähtö:
3.1416 3.14159 3.14159 3.141590000
Esimerkki 2
Katsotaanpa toinen yksinkertainen esimerkki:
#include #include #include #include using namespace std; int main() { const long double pi = acos(-1.L); cout << 'default precision (6): ' << pi << ' ' << 'setprecision(10): ' << setprecision(10) << pi << ' ' << 'max precision:' << setprecision(numeric_limits::digits10 + 1) << pi << ' '; return 0; }
Lähtö:
default precision (6): 3.14159 setprecision(10): 3.141592654 max precision:3.141592653589793239
Esimerkki 3
Katsotaanpa toinen yksinkertainen esimerkki:
attribuuttivirhe python
#include #include using namespace std; int main (void) { float a,b,c; a = 5; b = 3; c = a/b; cout << setprecision (1) << c << endl; cout << setprecision (2) << c << endl; cout << setprecision (3) << c << endl; cout << setprecision (4) << c << endl; cout << setprecision (5) << c << endl; cout << setprecision (6) << c << endl; return 0; }
Lähtö:
2 1.7 1.67 1.667 1.6667 1.66667