#include <math.h> // <cmath> en C++
double nexttoward( double x, long double y ); // C99
float nexttowardf( float x, long double y ); // C99
long double nexttowardl( long double x, long double y ); // C99
Ces trois fonctions renvoient la prochaine valeur représentable après x, dans la direction de y, y étant évalué en long double.
Ces éléments ont été ajoutés par la version C99 du standard du langage C.
Ces fonctions renvoient la prochaine valeur représentable dans le type de retour.
L'exemple suivant montre une utilisation simple de ces fonctions.
1 2 3 4 5 6 7 8 9 |
#include <math.h> #include <stdio.h> #include <stdlib.h> int main() { double value = nexttoward(1.0, 2.0L); printf( "value > 1.0 == %d\n", value > 1.0 ); return EXIT_SUCCESS; } |
Il est à noter que la librairie mathématique doit être ajoutée durant l'étape de "link" (édition des liens)
de votre exécutable. Cela se réalise en ajoutant l'option -lm à votre compilateur GCC. En cas
d'utilisation d'un autre compilateur, je vous renvoie vers la documentation de ce dernier.
$> gcc -o sample sample.c -lm $> ./sample value > 1.0 == 1 $>
Améliorations / Corrections
Vous avez des améliorations (ou des corrections) à proposer pour ce document : je vous remerçie par avance de m'en faire part, cela m'aide à améliorer le site.
Emplacement :
Description des améliorations :