我创建了一个具有限制器的简单步进控件。
它似乎总体上运作良好。但是,如果我尝试将限制器范围从numeric_limits<float>::min()
设置为numeric_limits<float>::max()
,则当值变为负值时,它无法正常工作。
这是我的完整测试代码。
#include <iostream>
using namespace std;
class Stepper {
public:
Stepper(float from, float to, float value, float interval){ //limited range
mFrom = from;
mTo = to;
mValue = value;
mInterval = interval;
}
Stepper(float value, float interval){ //limitless range version
mFrom = numeric_limits<float>::min();
mTo = numeric_limits<float>::max();
mValue = value;
mInterval = interval;
}
float getCurrentValue() {
return mValue;
}
float getDecreasedValue() {
if (mFrom < mTo)
mValue -= mInterval;
else
mValue += mInterval;
mValue = clamp(mValue, min(mFrom, mTo), max(mFrom, mTo));
return mValue;
}
float getIncreasedValue() {
if (mFrom < mTo)
mValue += mInterval;
else
mValue -= mInterval;
mValue = clamp(mValue, min(mFrom, mTo), max(mFrom, mTo));
return mValue;
}
private:
float clamp(float value, float min, float max) {
return value < min ? min : value > max ? max : value;
}
float mFrom, mTo, mValue, mInterval;
};
int main(int argc, const char * argv[]) {
bool shouldQuit = false;
// Stepper stepper(-3, 3, 0, 1); //this works
Stepper stepper(0, 1); //this doesn't work when the value becomes negative
cout << "step : " << stepper.getCurrentValue() << endl;
while (!shouldQuit) {
string inputStr;
cin >> inputStr;
if (inputStr == "-") //type in '-' decrease the step
cout << "step : " << stepper.getDecreasedValue() << endl;
else if (inputStr == "+") //type in '+' increase the step
cout << "step : " << stepper.getIncreasedValue() << endl;
else if (inputStr == "quit")
shouldQuit = true;
}
return 0;
}
我的类构造函数需要4个参数
- 最小限制值(也可以是最大值)
- 最大限制值(这也可以是最小值)
- 初始值
- 步骤间隔
醇>
此外,构造函数只能使用2个
参数
- 初始值
- 步骤间隔
醇>
这种情况下,限制器的范围从numeric_limits<float>::min()
到numeric_limits<float>::max()
。
但在这种情况下,如果值变为负数,则返回1.17549e-38
,其值与numeric_limits<float>::min()
相同。
有可能解决这个问题吗? 任何建议或指导将不胜感激!
答案 0 :(得分:2)
std::numeric_limits<float>::lowest()
是数学意义上的最低值。 std::numeric_limits<float>::min()
只是最小的正值(大于零)。
有关详细信息,请参阅this question。命名可以追溯到C.
答案 1 :(得分:1)
在我看来,min()
有一个不幸的名字。它的值是最小的,正的,标准化的浮点数。
使用lowest()
代替它,它包含真正的最小值。