strtoul(3) Library Functions Manual strtoul(3) NAAM strtoul, strtoull, strtouq - converteert een tekenreeks naar een positief lang geheel getal BIBLIOTHEEK Standard C bibliotheek (libc, -lc) SAMENVATTING #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); Feature Test Macro's eisen in glibc (zie feature_test_macros(7)): strtoull(): _ISOC99_SOURCE || /* glibc <= 2.19: */ _SVID_SOURCE || _BSD_SOURCE BESCHRIJVING De strtuol() functie converteert het initiele deel van een tekenreeks in nptr naar een positief lang geheel getal met als grondtal als grondtal, grondtal moet liggen tussen 2 en 36 (inclusief deze grenzen), of de speciale waarde 0. De tekenreeks mag beginnen met een willekeurig aantal witruimtes (zoals bepaald door isspace(3)) gevolgd door een enkel optioneel teken '+' or '-'. Als het grondtal nul of 16 is, dan mag de string "0x" of "0X" bevatten en wordt het getal gelezen met 16 als grondtal; in andere gevallen zal het grondtal 0 geinterpreteerd worden als 10 (decimaal) behalve als het volgende teken '0' is, in welk geval het geinterpreteerd wordt als 8 (octaal). De rest van de tekenreeks zal geconverteerd worden naar een long waarde in de voor de hand liggende manier, eindigende bij het eerste ongeldige teken in het gekozen grondtal. (Grondtallen groter dan 10, vertegenwoordigd de letter 'A' in zowel hoofd- als kleine letter 10, 'B' vertegenwoordigd 11, en zo voorts, met 'Z' vertegenwoordigde 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. De strtoull() functie werkt net als de strtoul() functie maar geeft een positief-lang-lang gehele waarde terug. EIND WAARDE De strtoul() functie retourneert het resultaat van een conversie, of als er sprake was van een leidend min-teken, de negatie van het resultaat van de conversie gerepresenteerd als een positieve waarde,, behalve als de originele (niet-negatie) waarde zou onderlopen; in het laatste geval, retourneert strtoul() ULONG_MAX en zet errno op ERANGE. Precies hetzelfde is geldig voor strtoull() (met ULLONG_MAX in plaats van ULONG_MAX). FOUTEN This function does not modify errno on success. EINVAL (niet in C99) Het gegeven grondtal bevat een niet ondersteunde waarde. ERANGE De resulterende waarde was buiten bereik. De implementatie mag errno zetten op EINVAL in het geval dat er geen omzetting plaats vond (geen cijfers gezien en 0 geretourneerd). ATTRIBUTEN Voor een uitleg van de termen in deze sectie, zie attributes(7). +-----------------------------+-------------------+--------------------+ |Interface | Attribuut | Waarde | +-----------------------------+-------------------+--------------------+ |strtoul(), strtoull(), | Thread veiligheid | MT-Safe taalgebied | |strtouq() | | | +-----------------------------+-------------------+--------------------+ VOLDOET AAN C11, POSIX.1-2008. GESCHIEDENIS strtoul() POSIX.1-2001, C89, SVr4. strtoull() POSIX.1-2001, C99. OPMERKINGEN Omdat strtoul() legitiem 0, ULONG_MAX, of ULONG_MIN (LLONG_MAX of LLONG_MIN voor strtoull()) kan retourneren bij zowel succes of falen, moet het aanroepende programma errno op 0 zetten voor de aanroep, en vervolgens bepalen of een fout optrad door te controleren of errno een niet-nul waarde heeft na de aanroep. Volgens POSIX.1, in taalgebieden anders dan "C" en "POSIX", mogen deze functies andere, implementatie afhankelijke numerieke tekenreeksen accepteren. BSD heeft ook u_quad_t strtouq(const char *nptr, char **endptr, int grondtal); met complete vergelijkbare definitie. Afhankelijk van de woordgrootte van de huidige architectuur, kan dit equivalent zijn aan strtoull() of aan strtoul(). Negatieve waarden worden beschouwd als geldige invoer and worden stilzwijgend omgezet naar een equivalente unsigned long waarde. VOORBEELDEN Zie het voorbeeld in de strtol(3) handleiding; het gebruik van de functies beschreven in deze handleiding is vergelijkbaar. ZIE OOK a64l(3), atof(3), atoi(3), atol(3), strtod(3), strtol(3), strtoumax(3) VERTALING De Nederlandse vertaling van deze handleiding is geschreven door Mario Blattermann en Luc Castermans Deze vertaling is vrije documentatie; lees de GNU General Public License Version 3 of later over de Copyright-voorwaarden. Er is geen AANSPRAKELIJKHEID. Indien U fouten in de vertaling van deze handleiding zou vinden, stuur een e-mail naar . Linux man-pages 6.06 19 december 2023 strtoul(3)