Partager via


Avertissement du compilateur (niveau 3) C4738

Mise à jour : novembre 2007

Message d'erreur

stockage de résultat flottant 32 bits en mémoire, perte possible de performances
storing 32-bit float result in memory, possible loss of performance

L'erreur C4738 signale que le résultat d'une assignation, d'un cast, d'un argument passé, ou d'une autre opération risque de devoir être arrondi ou que l'opération est tombée à court de registres et a dû utiliser de la mémoire (débordement). Cela peut entraîner une perte de performances.

Pour remédier à cet avertissement et éviter tout arrondi, compilez avec /fp:fast ou utilisez des double plutôt que des float.

Pour remédier à cet avertissement et éviter de manquer de registres, modifiez l'ordre de calcul et votre utilisation de la fonctionnalité inlining

Cet avertissement est désactivé par défaut. Pour plus d'informations, consultez Avertissements du compilateur désactivés par défaut.

Exemple

L'exemple suivant génère l'erreur 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);
}