In deze zelfstudie leren we met behulp van voorbeelden hoe we tekenreeksen kunnen converteren naar getallen met drijvende komma en vice versa.
C ++ string om te zweven en dubbele conversie
De eenvoudigste manier om een tekenreeks naar een getal met drijvende komma te converteren, is door deze C ++ 11- functies te gebruiken:
- std :: stof () - converteren
string
naarfloat
- std :: stod () - converteren
string
naardouble
- std :: stold () - converteren
string
naarlong double
.
Deze functies zijn gedefinieerd in het string
header-bestand.
Voorbeeld 1: C ++ string om te zweven en te verdubbelen
#include #include int main() ( std::string str = "123.4567"; // convert string to float float num_float = std::stof(str); // convert string to double double num_double = std::stod(str); std:: cout<< "num_float = " << num_float << std::endl; std:: cout<< "num_double = " << num_double << std::endl; return 0; )
Uitvoer
num_float = 123.457 num_double = 123.457
Voorbeeld 2: C ++ char Array to double
We kunnen een char
array converteren naar double
door de std::atof()
functie te gebruiken.
#include // cstdlib is needed for atoi() #include int main() ( // declaring and initializing character array char str() = "123.4567"; double num_double = std::atof(str); std::cout << "num_double = " << num_double << std::endl; return 0; )
Uitvoer
num_double = 123.457
C ++ float en double to string Conversion
We kunnen zetten float
en double
om string
het gebruik van de C ++ 11 std::to_string()
-functie. Voor de oudere C ++ - compilers kunnen we std::stringstream
objecten gebruiken.
Voorbeeld 3: zwevend en dubbel naar string met to_string ()
#include #include int main() ( float num_float = 123.4567F; double num_double = 123.4567; std::string str1 = std::to_string(num_float); std::string str2 = std::to_string(num_double); std::cout << "Float to String = " << str1 << std::endl; std::cout << "Double to String = " << str2 << std::endl; return 0; )
Uitvoer
Zweven naar String = 123.456703 Dubbel naar String = 123.456700
Voorbeeld 4: float en double to string Stringstream gebruiken
#include #include #include // for using stringstream int main() ( float num_float = 123.4567F; double num_double = 123.4567; // creating stringstream objects std::stringstream ss1; std::stringstream ss2; // assigning the value of num_float to ss1 ss1 << num_float; // assigning the value of num_float to ss2 ss2 << num_double; // initializing two string variables with the values of ss1 and ss2 // and converting it to string format with str() function std::string str1 = ss1.str(); std::string str2 = ss2.str(); std::cout << "Float to String = " << str1 << std::endl; std::cout << "Double to String = " << str2 << std::endl; return 0; )
Uitvoer
Zweven naar String = 123.457 Dubbel naar String = 123.457
Aanbevolen literatuur: C ++ - string tot int.