Passando flutuar para uma função em C++ aparece para alterar precisão

0

Pergunta

Esta é uma pergunta noob, mas eu estou curioso para saber a razão por trás disso: -Se eu depuração a C++ seguinte código:

void floatreturn(float i){
      //nothing
}

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

Monitoramento o valor passado de um, parece ser 23.9759998 ao entrar floatreturn. Como resultado, qualquer transformação do valor em que a função seria necessário para ajustar manualmente a precisão. Há um motivo para isso, e de alguma forma evitá-lo?

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

Melhor resposta

0

O problema aconteceu antes floatreturn(a);.
Foi o que aconteceu na float a = 23.976;
floatreturn(a); é irrelevante.

Há cerca de 2^32 diferentes valores que float pode codificar exatamente. 23.976 não é um deles. O mais próximo encodable float é sobre 23.9759998...

Para evitar, use valores que podem exatamente codificar como um float ou tolerar fechar - se a cerca de 1 parte 224

2021-11-24 16:43:03

Graças Marcar para o link e chux para a resposta concisa.
mv_p

Apenas mais uma de ensino ponto para mim: por que não cout padrão para uma precisão de 3 casas decimais se nós reimprimir a variável sem definição de precisão para a saída? Recebo-se que o armazenamento a bóia irá sempre retornar o mais próximo flutuante binário possível, e que o cout é de arredondamento.
mv_p

@mv_p Qual foi o exato resultado que você viu?
chux - Reinstate Monica

com um simples 'float x = 23.976; cout << x;' eu ver "23.976"
mv_p

Em outros idiomas

Esta página está em outros idiomas

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