在C 98中的长双转换
String to long double conversion in c++98
本文关键字:转换 更新时间:2023-10-16
有人知道如何将string
转换为long double
吗?例如,假设我们有
string S = "3.236568949"
我想将字符串内的内容转换为一个长的双变量x
。
注意:在C 11中,它们的存在stold
功能确实如此,但我使用的是C 98不是C 11。 另外,我不需要以某些精度来表达字符串,因为我已经知道setprecision
功能,但是我想要的只是转换为long double
。在其他病房中,我需要x等于字符串内的 eacter 编号,而不是数字的近似版本。最后,我想告诉你我的字符串包含一个有效的数字。
您可以使用C函数:
#include <stdlib.h>
int main(){
char* convertme="3.236568949";
double converted=atof(convertme);
return 0;
}
您可以使用std::stringstream
将字符串转换为long double
。std::stringstream
的作用就像cin
一样,但没有从用户获得输入,而是使用std::string
加载到流中。看起来像
std::string data = "3.236568949"
std::stringstream ss(data);
long double ld;
ss >> ld;
请注意,在处理浮点号时,您将不得不处理不精确。有关此的更多信息,请参见浮点数学损坏?
您可以从C99中使用strtold()
函数:
long double d = strtold( str.c_str(), nullptr );
将std::string
转换为long double
。尽管浮点表示近似,因此没有人可以保证转换后的值完全相同。
相关文章:
- 防止主数据类型C++的隐式转换
- 模板参数替换失败,并且未完成隐式转换
- 努力将整数转换为链表。不知道我在这里做错了什么
- HEX值到wchar_t字符(UTF-8)的转换
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将 Qvector<uint8_t> 转换为 QString
- 如何在cuSparse中使用cusparseXcoo2csr从coo转换为csc
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 在c++中使用nlohmann从类到json的转换
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- 复制列表初始化的隐式转换的等级是多少
- 正在将指针转换为范围
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 是否可以从int转换为enum类类型
- 了解 GLM- openGL 中的相机转换
- 将无符号char*转换为std::istream*C++