如何(安全)除以最大值,得到浮点值?

用户名

我要计算转换系数。为此,我必须将例如ushort的最大值除以uchar的最大值。

我想通过将参数传递给函数或类型名来动态地执行此操作。然后,我要选择最大值并执行计算。

有两个问题:

  1. 如何动态选择最大值?
  2. 如何安全地将两个值相除?

已知所有值都适合double的范围。

理想情况下,我想做类似的事情:

double x = numeric_limits<T>::max / numeric_limits<T2>::max;

但是,这是不正确/可能的。

沃利

您提出的想法应该可行:

#include <iostream>
#include <limits>

template <typename T, typename T2>
double get_ratio()
{
    return static_cast<double>(std::numeric_limits<T>::max()) / std::numeric_limits<T2>::max();
}

int main()
{
    auto ratio = get_ratio<unsigned short, unsigned char>();
    std::cout << ratio << '\n';
    return 0;
}

演示

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章