logo

Precisão do conjunto do manipulador C++

Precisão do conjunto do manipulador C++ A função é usada para controlar o número de dígitos de uma exibição de fluxo de saída de um valor de ponto flutuante.

Este manipulador é declarado no arquivo de cabeçalho.

Sintaxe

 /*unspecified*/ setprecision (int n); 

Parâmetro

n : novo valor para a precisão decimal.

Valor de retorno

Esta função retorna um objeto de tipo não especificado. A função setbase deve ser usada apenas como um manipulador de fluxo.

Corridas de dados

O objeto de fluxo no qual ele é inserido ou extraído é modificado e o acesso simultâneo ao mesmo objeto de fluxo pode introduzir corridas de dados.

Exceções

O objeto está em um estado válido, se alguma exceção for lançada.

Exemplo 1

Vejamos o exemplo simples para demonstrar o uso do setprecision:

 #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; } 

Saída:

tupla ordenada em python
 3.1416 3.14159 3.14159 3.141590000 

Exemplo 2

Vejamos outro exemplo simples:

 #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; } 

Saída:

 default precision (6): 3.14159 setprecision(10): 3.141592654 max precision:3.141592653589793239 

Exemplo 3

Vejamos outro exemplo simples:

 #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; } 

Saída:

 2 1.7 1.67 1.667 1.6667 1.66667