C ++ String lebegni / duplázni és fordítva

Ebben az oktatóanyagban megtanuljuk, hogyan lehet a karakterláncot lebegőpontos számokká alakítani, és fordítva, példák segítségével.

C ++ karakterlánc lebegéshez és dupla konverzió

A karakterláncot legegyszerűbben lebegőpontos számokká alakíthatjuk át, ha ezeket a C ++ 11 függvényeket használjuk:

  • std :: stof () - megtérít stringafloat
  • std :: Stod () - megtérít stringadouble
  • std :: stold () - konvertálás stringerre long double.

Ezeket a függvényeket a stringfejlécfájl határozza meg .

1. példa: C ++ karakterlánc lebegéshez és duplázáshoz

 #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; )

Kimenet

 num_float = 123.457 num_double = 123.457

2. példa: C ++ char tömb duplázáshoz

A chartömböt átalakíthatjuk doublea std::atof()függvény használatával.

 #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; )

Kimenet

 szám_dupla = 123,457

C ++ lebegő és dupla karakterlánc átalakítás

Mi lehet konvertálni float, és doublehogy stringa C ++ 11 std::to_string() funkciót. A régebbi C ++ fordítóknál std::stringstreamobjektumokat használhatunk .

3. példa: lebegés és duplázás a karaktersorozathoz a

 #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; )

Kimenet

 Float to String = 123.456703 dupla karakterlánc = 123.456700

4. példa: lebeg és duplázza a karakterláncra stringstream használatával

 #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; )

Kimenet

 Float to String = 123,457 Dupla karakterlánc = 123,457

Ajánlott olvasmány: C ++ karakterlánc int.

érdekes cikkek...