The first argument is the string. It has to be passed in as a C string, so if you have a std::string
use .c_str()
first.
The second argument is optional, and specifies a char *
to store a pointer to the character after the end of the number. This is useful when converting a string containing several integers, but if you don't need it, just set this argument to NULL.
The third argument is the radix (base) to convert. strtol
can do anything from binary (base 2) to base 36. If you want strtol
to pick the base automatically based on prefix, pass in 0.
So, the simplest usage would be
long l = strtol(input.c_str(), NULL, 0);
If you know you are getting decimal numbers:
long l = strtol(input.c_str(), NULL, 10);
strtol
returns 0 if there are no convertible characters at the start of the string. If you want to check if strtol
succeeded, use the middle argument:
const char *s = input.c_str();
char *t;
long l = strtol(s, &t, 10);
if(s == t) {
/* strtol failed */
}
If you're using C++11, use stol
instead:
long l = stol(input);
Alternately, you can just use a stringstream
, which has the advantage of being able to read many items with ease just like cin
:
stringstream ss(input);
long l;
ss >> l;
strtol
instead of astringstream
to read a number? – Foldboatint number = strtol(input.**c_str()**, ...);
? – Alewifestd::stol
. – Prostate