strtoul(3) Library Functions Manual strtoul(3) NOM strtoul, strtoull, strtouq - Convertir une chaine en entier long non signe BIBLIOTHEQUE Bibliotheque C standard (libc, -lc) SYNOPSIS #include unsigned long strtoul(const char *restrict nptr, char **restrict endptr, int base); unsigned long long strtoull(const char *restrict nptr, char **restrict endptr, int base); Exigences de macros de test de fonctionnalites pour la glibc (consulter feature_test_macros(7)) : strtoull() : _ISOC99_SOURCE || /* glibc <= 2.19: */ _SVID_SOURCE || _BSD_SOURCE DESCRIPTION La fonction strtoul() convertit le debut de la chaine nptr en une valeur de type unsigned long en fonction de l'argument base, qui doit etre dans l'intervalle 2 a 36 (bornes comprises), ou avoir la valeur speciale 0. La chaine peut commencer par un nombre quelconque d'espaces (tels que definis par isspace(3)) suivis d'un eventuel signe << + >> ou << - >>. Si base vaut 0 ou 16, la chaine peut inclure un prefixe << 0x >> et le nombre sera interprete en base 16. Sinon, une base valant zero est interpretee comme 10 (base decimale) sauf si le caractere suivant est << 0 >>, auquel cas la base est 8 (base octale). Le reste de la chaine est converti en une valeur de type unsigned long, en s'arretant au premier caractere qui n'est pas un chiffre valable dans la base indiquee. Dans les bases superieures a 10, la lettre << A >> (majuscule ou minuscule) represente 10, << B >> represente 11, et ainsi de suite jusqu'a << Z >> representant 35. If endptr is not NULL, and the base is supported, strtoul() stores the address of the first invalid character in *endptr. If there were no digits at all, strtoul() stores the original value of nptr in *endptr (and returns 0). In particular, if *nptr is not '\0' but **endptr is '\0' on return, the entire string is valid. La fonction strtoull() fonctionne comme strtoul(), mais renvoie une valeur entiere de type unsigned long long. VALEUR RENVOYEE La fonction strtoul() renvoie soit le resultat de la conversion, soit, s'il y avait un signe moins en tete, l'oppose du resultat de la conversion representee comme une valeur non signee, a moins que la valeur originale ne provoque un debordement, auquel cas strtoul() renvoie ULONG_MAX et errno contient le code d'erreur ERANGE. La meme chose est vraie pour strtoull() avec ULLONG_MAX a la place de ULONG_MAX. ERREURS This function does not modify errno on success. EINVAL (pas dans C99) La base indiquee n'est pas prise en charge. ERANGE La valeur retournee est hors limites. L'implementation peut aussi mettre errno a EINVAL si aucune conversion n'a ete realisee (pas de chiffres trouves, et 0 renvoye). ATTRIBUTS Pour une explication des termes utilises dans cette section, consulter attributes(7). +--------------------------+--------------------------+----------------+ |Interface | Attribut | Valeur | +--------------------------+--------------------------+----------------+ |strtoul(), strtoull(), | Securite des threads | MT-Safe locale | |strtouq() | | | +--------------------------+--------------------------+----------------+ STANDARDS C11, POSIX.1-2008. HISTORIQUE strtoul() POSIX.1-2001, C89, SVr4. strtoull() POSIX.1-2001, C99. NOTES Comme strtoul() peut legitimement renvoyer 0 ou ULONG_MAX (ULLONG_MAX pour strtoull()) a la fois en cas de succes et d'echec, le programme appelant doit positionner errno a 0 avant l'appel, et determiner si une erreur s'est produite en regardant si errno a une valeur non nulle apres l'appel. Dans des localisations autres que << C >>, d'autres chaines peuvent etre acceptees. Par exemple, un signe separateur de milliers pour la localisation utilisee peut etre accepte. BSD a aussi u_quad_t strtouq(const char *nptr, char **endptr, int base); avec une definition exactement analogue. Suivant l'architecture, cela peut etre equivalent a strtoull() ou strtoul(). Des valeurs negatives sont considerees comme valables et sont converties en une valeur de type unsigned long equivalente sans avertissement. EXEMPLES Consultez l'exemple dans la page de manuel strtol(3) ; l'utilisation des fonctions decrites dans cette page de manuel est identique. VOIR AUSSI a64l(3), atof(3), atoi(3), atol(3), strtod(3), strtol(3), strtoumax(3) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot et Gregoire Scano Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.06 19 decembre 2023 strtoul(3)