ceil, ceilf, ceil - Plus petit entier supérieur ou égal à x
Bibliothèque de math (
libm,
-lm)
#include <math.h>
double ceil(double x);
float ceilf(float x);
long double ceill(long double x);
ceilf(),
ceill() :
_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
|| /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE
|| /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE
Ces fonctions renvoient le plus petit nombre entier n'étant pas
strictement inférieur à
x.
Par exemple,
ceil(0,5) vaut 1,0 et
ceil(-0,5) vaut 0,0.
Ces fonctions renvoient la partie entière de
x par excès.
Si
x est un nombre entier, +0, -0, NaN ou une valeur infinie, la valeur
x elle-même est renvoyée.
Aucune erreur ne se produit. POSIX.1-2001 documente une série d'erreurs
pour les dépassements, mais consultez la section NOTES.
Pour une explication des termes utilisés dans cette section, consulter
attributes(7).
Interface |
Attribut |
Valeur |
ceil(), ceilf(), ceill() |
Sécurité des threads |
MT-Safe |
C99, POSIX.1-2001, POSIX.1-2008.
La variante renvoyant
double est également conforme à SVr4,
4.3BSD.
Les spécifications SUSv2 et POSIX.1-2001 contiennent un passage sur les
dépassements (qui peuvent remplir
errno avec
ERANGE ou
déclencher une exception
FE_OVERFLOW). En pratique, aucun
dépassement ne peut se produire sur les machines actuelles, ce qui rend
inutile cette gestion d'erreur. Plus précisément, le
dépassement ne peut se produire que si la valeur maximale de l'exposant
est plus petite que le nombre de bits de la mantisse. Pour les nombres en
virgule flottante 32 bits et 64 bits obéissant à
la norme IEEE-754, la valeur maximale de l'exposant est 127 (resp. 1023) et le
nombre de bits de la mantisse est 24 (resp. 53).
La partie entière renvoyée par ces fonctions peut être trop
grande pour être stockée dans un type entier (
int,
long, etc.). Pour éviter les dépassements, qui produiront
des résultats indéfinis, une application devrait vérifier
la validité de la valeur renvoyée avec l'intervalle
accepté avant de l'affecter à un type entier.
floor(3),
lrint(3),
nearbyint(3),
rint(3),
round(3),
trunc(3)
La traduction française de cette page de manuel a été
créée par Christophe Blaess
<
https://www.blaess.fr/christophe/>, Stéphan Rafin
<
[email protected]>, Thierry Vignaud
<
[email protected]>, François Micaux, Alain Portal
<
[email protected]>, Jean-Philippe Guérard
<
[email protected]>, Jean-Luc Coulon (f5ibh)
<
[email protected]>, Julien Cristau
<
[email protected]>, Thomas Huriaux <
[email protected]>,
Nicolas François <
[email protected]>, Florentin
Duneau <
[email protected]>, Simon Paillard
<
[email protected]>, Denis Barbier
<
[email protected]>, David Prévot <
[email protected]>,
Cédric Boutillier <
[email protected]> et Jean-Pierre
Giraud <
[email protected]>
Cette traduction est une documentation libre ; veuillez vous reporter
à la
GNU
General Public License version 3 concernant les conditions de copie
et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.
Si vous découvrez un bogue dans la traduction de cette page de manuel,
veuillez envoyer un message à
[email protected]