Udostępnij za pośrednictwem


Kompilator ostrzeżenia (poziom 3) C4738

przechowywanie wyników 32-bitowych zmiennoprzecinkowych w pamięci, ewentualnej utraty wydajności

C4738 ostrzega, że wynik przydziału, oddanych przekazany argument lub innych operacji może być konieczne zaokrąglone lub że operacji zabrakło rejestrów i konieczne do używania pamięci (przechodzenia).Może to spowodować zmniejszenie wydajności.

Aby rozwiązać to ostrzeżenie i uniknąć zaokrąglania, kompilacji z /fp:fast lub doubles zamiast floats.

Aby rozwiązać to ostrzeżenie i uniknąć braku rejestrów, zmienić kolejność obliczeń i modyfikować korzystanie z inline

To ostrzeżenie jest domyślnie wyłączona.Aby uzyskać więcej informacji, zobacz Kompilator ostrzeżenia że są wyłączone domyślnie.

Przykład

Poniższy przykład generuje 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);
}