在c ++中将长双文字后缀附加到用户输入
Appending long double literal suffix to user inputs in c++
我有一个 class 有一个长双向量:
MyClass{
vector<long double> myvec;
public:
MyClass(){ //Constructor }
// Some memeber functions that operate on the vector
};
我已使输入运算符超载,我正在从用户那里获取输入,然后将其推入矢量。我遇到的问题是,如果用户输入的数字超出双精度范围,则代码应将长双精度后缀追加到输入中,而用户也没有。这是我到目前为止尝试过的:
long double input;
...
input = (long double)(input + "L");
myvec.push_back(input);
我想过使用 scanf,但我不确定在重载输入运算符时使用它的安全性如何。
使用std::stold
将输入文本转换为long double。不需要后缀; stold
会做对的。源代码中需要后缀来告诉编译器文本代表什么类型。当您从外部源读取时,编译器不参与,因此您必须自己整理类型。
后缀仅适用于文字值,例如auto x = 12345.0L
。您使用它们来防止隐式转换,因为浮点文字的默认类型是 double
.
您不能在命名变量上使用它们。
问题是您如何获得输入?
我有一个 class 有一个长双向量:
MyClass{
vector<long double> myvec;
public:
MyClass(){ //Constructor }
// Some memeber functions that operate on the vector
};
我已使输入运算符超载,我正在从用户那里获取输入,然后将其推入矢量。我遇到的问题是,如果用户输入的数字超出双精度范围,则代码应将长双精度后缀追加到输入中,而用户也没有。这是我到目前为止尝试过的:
long double input;
...
input = (long double)(input + "L");
myvec.push_back(input);
我想过使用 scanf,但我不确定在重载输入运算符时使用它的安全性如何。
使用std::stold
将输入文本转换为long double。不需要后缀; stold
会做对的。源代码中需要后缀来告诉编译器文本代表什么类型。当您从外部源读取时,编译器不参与,因此您必须自己整理类型。
后缀仅适用于文字值,例如auto x = 12345.0L
。您使用它们来防止隐式转换,因为浮点文字的默认类型是 double
.
您不能在命名变量上使用它们。
问题是您如何获得输入?