Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
armazenar float de 32 bits resulta em memória, possível perda de desempenho
Observações
C4738 avisa que o resultado de uma atribuição, elenco, argumento passado ou outra operação pode precisar ser arredondado ou que a operação ficou sem registros e precisou usar memória (derramamento). Isso pode resultar em perda de desempenho.
Para resolver esse aviso e evitar arredondamentos, compile com /fp:fast ou use double em vez de float.
Para resolver este aviso e evitar ficar sem registos, altere a ordem de cálculo e modifique a sua utilização de inlining
Este aviso está desativado por padrão. Para obter mais informações, consulte Avisos do compilador que estão desativados por padrão.
Example
O exemplo a seguir gera C4738:
// C4738.cpp
// compile with: /c /fp:precise /O2 /W3
// processor: x86
#include <stdio.h>
#pragma warning(default : 4738)
float func(float f)
{
return f;
}
int main()
{
extern float f, f1, f2;
double d = 0.0;
f1 = func(d);
f2 = (float) d;
f = f1 + f2; // C4738
printf_s("%f\n", f);
}