std::strtof,std::strtod,std::strtold (3) - Linux Manuals
std::strtof,std::strtod,std::strtold: std::strtof,std::strtod,std::strtold
NAME
std::strtof,std::strtod,std::strtold - std::strtof,std::strtod,std::strtold
Synopsis
Defined in header <cstdlib>
float strtof( const char* str, char** str_end ); (since C++11)
double strtod( const char* str, char** str_end );
long double strtold( const char* str, char** str_end ); (since C++11)
Interprets a floating point value in a byte string pointed to by str.
Function discards any whitespace characters (as determined by std::isspace()) until first non-whitespace character is found. Then it takes as many characters as possible to form a valid floating-point representation and converts them to a floating-point value. The valid floating-point value can be one of the following:
* decimal floating-point expression. It consists of the following parts:
* binary floating-point expression. It consists of the following parts:
* infinity expression. It consists of the following parts:
* not-a-number expression. It consists of the following parts:
* any other expression that may be accepted by the currently installed C locale
The functions sets the pointer pointed to by str_end to point to the character past the last character interpreted. If str_end is NULL, it is ignored.
Parameters
str - pointer to the null-terminated byte string to be interpreted
str_end - pointer to a pointer to character.
Return value
Floating point value corresponding to the contents of str on success. If the converted value falls out of range of corresponding return type, range error occurs and HUGE_VAL, HUGE_VALF or HUGE_VALL is returned. If no conversion can be performed, 0 is returned and *str_end is set to str.
Example
// Run this code
Output:
See also
atof (function)
wcstof converts a wide string to a floating point value
wcstod (function)
wcstold
from_chars converts a character sequence to an integer or floating-point value
(C++17)