Defined in header <stdlib.h> | ||
---|---|---|
int atoi( const char *str ); | ||
long atol( const char *str ); | ||
long long atoll( const char *str ); | (since C99) |
Interprets an integer value in a byte string pointed to by str
.
Discards any whitespace characters until the first non-whitespace character is found, then takes as many characters as possible to form a valid integer number representation and converts them to an integer value. The valid integer value consists of the following parts:
str | - | pointer to the null-terminated byte string to be interpreted |
Integer value corresponding to the contents of str
on success.
If no conversion can be performed, 0
is returned.
If the value of the result cannot be represented, i.e. the converted value falls out of range of the corresponding return type, behavior is undefined.
The name stands for "ASCII to integer".
#include <stdio.h> #include <stdlib.h> int main(void) { printf("%i\n", atoi(" -123junk")); printf("%i\n", atoi(" +321dust")); printf("%i\n", atoi("0")); printf("%i\n", atoi("junk")); // no conversion can be performed printf("%i\n", atoi("2147483648")); // UB: out of range of int }
Possible output:
-123 321 0 0 -2147483648
(C99) | converts a byte string to an integer value (function) |
(C99) | converts a byte string to an unsigned integer value (function) |
(C95)(C99) | converts a wide string to an integer value (function) |
(C95)(C99) | converts a wide string to an unsigned integer value (function) |
C++ documentation for atoi, atol, atoll |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/c/string/byte/atoi