我想将boost :: units用于某些SI指标。但是我们的代码主要处理毫米而不是使用
quantity<length> value = 1*milli*meter;
我们更喜欢像
这样的东西quantity<length> value = 1*millimeter;
但是我不确定如何定义“毫米”(不使用#define)。
其次,使用前缀单位的开销是多少?
更新:这需要在没有C ++ 11功能(即没有UDL)的情况下运行
答案 0 :(得分:12)
C ++ 11确实是最简单的解决方案。你可以做到
static const auto millimeter = milli * meter;
或
auto operator"" _mm (long double val) -> decltype(val * milli * meter)
{
return val * milli * meter;
}
只要您不转换为其他前缀,就不会有性能损失。即使你这样做也应该可以忽略不计。
如果您不想使用C ++ 11,则需要查找表达式milli * meter
的相应类型,但您可以将auto
替换为int
并阅读编译器消息。
答案 1 :(得分:6)
我使用以下方法:
// your namespace name for units
namespace outernamespace {
namespace millimeter_system {
typedef boost::units::scaled_base_unit<boost::units::si::meter_base_unit, boost::units::scale<10, boost::units::static_rational<-3>>> millimeter_base_unit;
typedef boost::units::make_system<millimeter_base_unit>::type system;
typedef boost::units::unit<boost::units::length_dimension, system> length;
BOOST_UNITS_STATIC_CONSTANT(millimeter, length);
BOOST_UNITS_STATIC_CONSTANT(millimeters, length);
}
typedef boost::units::quantity<millimeter_system::length> quantity_millimeter;
using millimeter_system::millimeter;
using millimeter_system::millimeters;
}
// demonstration of usage
void foo() {
using namespace outernamespace;
using namespace boost::units;
using namespace boost::units::si;
quantity_millimeter mm = 5 * millimeter;
quantity<boost::units::si::length> m = 0.004 * meter;
if (mm < static_cast<quantity_millimeter>(m)) {
std::cout << 'lt ' << std::endl;
}
else {
std::cout << 'geq ' << std::endl;
}
}
答案 2 :(得分:-2)
如果你有一个支持C ++ 11的编译器,你可以使用User Defined Literals来定义你的单位。
double operator"" _millimeter ( double value )
{
return value;
}
您可以这样使用:
double foo = 1000_millimeter;