Compiler le code suivant:
double getDouble()
{
double value = 2147483649.0;
return value;
}
int main()
{
printf("INT_MAX: %u\n", INT_MAX);
printf("UINT_MAX: %u\n", UINT_MAX);
printf("Double value: %f\n", getDouble());
printf("Direct cast value: %u\n", (unsigned int) getDouble());
double d = getDouble();
printf("Indirect cast value: %u\n", (unsigned int) d);
return 0;
}
Sorties (MSVC x86):
INT_MAX: 2147483647
UINT_MAX: 4294967295
Double value: 2147483649.000000
Direct cast value: 2147483648
Indirect cast value: 2147483649
Sorties (MSVC x64):
INT_MAX: 2147483647
UINT_MAX: 4294967295
Double value: 2147483649.000000
Direct cast value: 2147483649
Indirect cast value: 2147483649
Dans la documentation Microsoft, il n'est pas fait mention de la valeur maximale de l'entier signé dans les conversions de double
à unsigned int
.
Toutes les valeurs ci INT_MAX
- dessus sont tronquées au 2147483648
moment où il s'agit du retour d'une fonction.
J'utilise Visual Studio 2019 pour créer le programme. Cela ne se produit pas sur gcc .
Est-ce que je fais quelque chose de mal? Yat - il un moyen sûr de convertir double
à unsigned int
?